History: API
Source of version: 24
Copy to clipboard
! API ((Tiki24)) now has an API, leveraging [https://packagist.org/packages/swagger-api/swagger-ui|swagger-api/swagger-ui] First commit: https://gitlab.com/tikiwiki/tiki/-/merge_requests/1028 !! Tiki 24+ A self-documented REST API has been added to Tiki 24 exposing the (arguably) most commonly used elements of the system. !!! Getting Started Enable API access via Admin -> Security tab. {REMARKSBOX(type="tip" title="Enable API access" close="n" store_cookie="n")} In the Control Panel, the screenshot below shows how to enable API access: * Check the box "API access" * Click "Apply" to save your choice. {img src="display1824" link="display1824" width="555" rel="box[g]" desc="Enable API access" styleimage="border" alt="Enable API access"} {REMARKSBOX} !!! Documentation The Documentation is embedded in Tiki. See /api/ on your target Tiki 24+ installation for an [https://doc.tiki.org/api/|OpenAPI 3.0 documentation] of the API. {REMARKSBOX(type="tip" title="Documentation page" close="n" store_cookie="n")} For example, let's assume that your Tiki 24+ instance is installed on -+https://yourtiki.xyz+-, then the page under -+https://yourtiki.xyz/api/+- should look alike: {img src="display1823" link="display1823" width="555" rel="box[g]" desc="API Documentation page" styleimage="border" alt="Tiki API Documentation"} !!!! Example: Let's -+GET+- the current Tiki version __GET/version Request__ * Parameters: No parameters * Type: application/json * Code snippet (assuming yourtiki.xyz has API feature enabled). {CODE(theme="default")}$ curl --request GET 'http://yourtiki.xyz/api/version'{CODE} __Responses__ * Value: {CODE()}{ "version": "24.1vcs" }{CODE} {REMARKSBOX} !!! Authorization API requests should be authenticated with a token created by Tiki admin (via Admin -> Security tab). Each token gives their owner access with one and only one Tiki user. ((Permissions)) configuration is then based on that Tiki ((User-Groups|user's groups)). {REMARKSBOX(type="tip" title="Authorization token" close="n" store_cookie="n")} Bearer token authorization header in format: {CODE()}Authorization: Bearer TOKEN{CODE} {REMARKSBOX} Tokens can be created in two ways: 1. Manually via Admin -> Security tab. Each token is associated with a user. Any API call using the token will act as the user observing all user's permissions. 2. Using Tiki OAuth 2.0 server. Documentation under /api/ on your target Tiki contains endpoints and parameters for different grant types. !!! OAuth 2.0 Server Tiki can act as an OAuth server. Admin -> Security tab has a link to manage authenticated clients. This section creates client IDs and secrets for 3rd party apps using Tiki API. Authorization flow can be: 1. Machine-to-machine - use client authorization grant type. Send your credentials directly to access_token endpoint to retrieve the access token. 2. End-user-to-machine - use auth flow grant type. Start by sending the user to authorize endpoint. This allows Tiki to ask target user for permission to grant access token with their user privileges. Once agreed, user is redirected back to your app/web app/machine where you do a machine-to-machine request to access_token endpoint to get the actual access token. Access tokens generated by Tiki OAuth server are JWT encoded. !!! Coverage: API endpoints include 1. Authorization flow. 2. API version. 3. Category CRUD + object categorization. 4. Comments CRUD + thread locking and moderation. 5. Groups CRUD + user association. 6. Search index rebuild and lookup. 7. Trackers/Fields/Items CRUD + special features like dump/export, clone, duplicate, clear. 8. Manage object translations. 9. User registration and CRUD operations, messaging and emailing wiki pages. 10. Wiki pages CRUD, locking and parsing/display. Major items still to be added: 1. Files and file galleries. 2. Articles, blogs, other wiki-related elements. 3. Calendars. !!- Pre-Tiki 24 notes Tiki can support wiki page updates (or data for most features in Tiki) by setting up ((data channels)) at this time. Adding a ((web service)) call to do it more directly would not be very hard so you can join in and ((dev:get your commit access))! From tiki-admin.php, you can activate: "HTTP Basic Authentication: Check credentials from HTTP Basic Authentication, useful to allow webservices to use credentials." Related: ((Token Access)) !!! Use of Tiki services Tiki's services live in -+lib/core/Services/+-. One can extrapolate the service URL from the file names and the names of the classes in the -+Controller.php+- files. This only works if you have activated SEFURL feature. Example: For accessing information which is also available from searches in the Tiki site, the class is -+action_lookup()+- in file -+lib/core/Services/Search/Controller.php+-. The path on tiki.org is: [https://tiki.org/tiki-search-lookup] To refine the search, the arguments are the same as for [https://doc.tiki.org/PluginList-filter-control-block] For example, in order to access the 45 first items from tracker 22, the syntax would be: [https://tiki.org/tiki-search-lookup?filter~type=trackeritem&filter~tracker_id=22&maxRecords=45] This works fine if called as ajax services from a page on the same Tiki. If done from outside Tiki from another online server, only data visible for ''anonymous user'' (not logged in) will be shown. In order to access data which is not visible to ''anonymous'' user, you may want to have a look at [https://doc.tiki.org/Token-Access]. !!! Controller pages Where you can find more specific information and samples for the different controllers * ((API Tracker)) !! Aliases * (alias(service URL)) * (alias(URL arguments))