All Projects → DieSchittigs → contao-content-api-bundle

DieSchittigs / contao-content-api-bundle

Licence: MIT license
Contao JSON-API

Programming Languages

PHP
23972 projects - #3 most used programming language
shell
77523 projects

Projects that are alternatives of or similar to contao-content-api-bundle

contao-ajax reload element
AjaxReloadElement for Contao Open Source CMS
Stars: ✭ 15 (-63.41%)
Mutual labels:  contao, contao-bundle
Contao4DummyBundle
Contao 4 Beispiel-Bundle / Tutorial
Stars: ✭ 27 (-34.15%)
Mutual labels:  contao-bundle, contao-extension
core
Bootstrap 4 Contao Core Component
Stars: ✭ 16 (-60.98%)
Mutual labels:  contao
check
Contao Check
Stars: ✭ 49 (+19.51%)
Mutual labels:  contao
contao-leads
No description or website provided.
Stars: ✭ 31 (-24.39%)
Mutual labels:  contao
docker-contao
Setup Contao Projects with docker
Stars: ✭ 21 (-48.78%)
Mutual labels:  contao
docs-archive
Contao Documentation
Stars: ✭ 44 (+7.32%)
Mutual labels:  contao
managed-edition
Contao Managed Edition
Stars: ✭ 15 (-63.41%)
Mutual labels:  contao
contao-events subscriptions
Contao extension that allows members of your website to subscribe to the events
Stars: ✭ 12 (-70.73%)
Mutual labels:  contao
contao-theme-framework
A new standardized and database-less way to build frontend themes in Contao.
Stars: ✭ 13 (-68.29%)
Mutual labels:  contao
contao-cookiebar
Display the information about cookies on your Contao website
Stars: ✭ 27 (-34.15%)
Mutual labels:  contao
catalog-manager
Backend Module ohne Programmierkenntnisse erstellen.
Stars: ✭ 28 (-31.71%)
Mutual labels:  contao

Contao Content API

We at Die Schittigs love Contao, but the web moves forward and static HTML templating just doesn't cut it anymore. Thus we came up with an easily digestible JSON-API to access Contao content via JavaScript (or anything else that can handle JSON).

With the Contao Content API it is possible to write the entire Frontend of your website in React.js, Angular, vue, or any other JS-framework. All while still using the great Contao Backend.

Requirements

You'll need an up-and-running Contao 4.4.x installation. Please note that the API is not compatible with Contao 3.x.

Installation

Install composer if you haven't already, enter this command in the main directory of your Contao installation:

composer require dieschittigs/contao-content-api

Contao Content API is now installed and ready to use.

Usage

Once installed, the following routes are available:

/api/sitemap

Gets the sitemap including the root pages.

Example

/api/sitemap/flat

Gets all pages as key value pairings where the key is the URL.

Example

/api/urls[?file=sitemap]

Gets all URLs from the generated sitemap XML(s). If you define a file, only that XML will be parsed.

Example

/api/page?url=/about/team.html

Gets the page, including all articles and contents at the url.

Example

/api/newsreader?url=/news/detail/new-website.html

Gets the news reader content from the url

Example

/api/?url=/page/or/newsarticle.html

Tries to get the page at the url, and contents from any reader

Example

/api/user

Gets the logged-in frontend user, if available.

Example

/api/module?id=5

Gets the content of a module by id

Example

/api/text?file=tl_news,modules

Gets the content of a language file by filename(s)

Example

/api/file?path=files/uploads&depth=2

Gets the file or directory at path and also it's children, limited by depth

Example

All routes also take the additional lang parameter (e.g. ?lang=de). If you need to override the language.

Configuration

Disabling the API

Edit your parameters.yml.

parameters:
…
content_api_enabled:
    false
…

The API routes are now all disabled. This may be helpful if you only want to use the classes included in the bundle.

Response headers

Edit your parameters.yml.

parameters:
…
content_api_headers:
    'Access-Control-Allow-Origin': 'https://mysite.org'
…

These headers will be added to all responses from the API.

Custom readers

Contao has the concept of Reader Module (e.g. News Reader). These can be inserted anywhere inside of an article where they read the URL to display their contents. If you want to add additional Reader Modules, you can do so by adding them in your parameters.yml.

parameters:
…
    content_api_readers:
        newsreader: NewsModel
        blogreader: BlogModel
…

Please note that the second parameter is the model class, not the module class. The new reader is now available at

/api/blogreader?url=/blog/detail/on-the-topic.html

or, if you want to include the whole page, at

/api?url=/blog/detail/on-the-topic.html

Internally the API tries to instantiate the model with the alias found in the url. It also tries to add all ContentModels it can find.

Hooks

We provide some basic hooks:

class Hooks{

    // $GLOBALS['TL_HOOKS']['apiBeforeInit']
    public static apiBeforeInit(Request $request){
        return $request
    }

    // $GLOBALS['TL_HOOKS']['apiAfterInit']
    public static apiAfterInit(Request $request){
        return $request
    }

    // $GLOBALS['TL_HOOKS']['apiContaoJson']
    public static apiContaoJson(ContaoJson $contaoJson, mixed $data){
        if($data instanceof ContentModel){
            $contaoJson->data = null;
            // End of the line
            return false;
        }
        // Do your thing, ContaoJson
        return true;

    }

    // $GLOBALS['TL_HOOKS']['apiResponse']
    public static apiResponse(mixed $data){
        $data->tamperedWith = true;
        return $data;

    }

    // $GLOBALS['TL_HOOKS']['apiModuleGenerated']
    public static function apiModuleGenerated(ApiModule $module, string $moduleClass)
    {
        // Override the way certain modules are handled
        if ($moduleClass != 'Contao\ModuleBlogList') {
            return;
        }
        $_module = new ModuleBlogList($module->model, null);
        $module->items = $_module->fetchItems(
            $module->category
        );
    }
}

Documentation

The classes crafted for the API might be a good starting point if you want to build anything on top of Contao.

Check out the docs here

Contribution

Bug reports and pull requests are very welcome :)


© Die Schittigs GmbH 2019

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].