eXo Platform 3.0 comes with a set of APIs to help you build your own applications from eXo services.
APIs vary according to level of maturity. It is important to understand the eXo's general approach to API change management.
The different levels of APIs are described in the following table:
| API Level | Test Suite | Clients | Documentation | Support | Compatibility X.Y.Z(+1) | Compatibility X.Y(+1) |
|---|---|---|---|---|---|---|
| Platform API |
|
|
|
|
|
|
| Provisional API |
|
|
|
|
|
|
| Experimental API |
|
|
| Best effort | Best effort |
|
| Unsupported API |
|
|
|
|
|
|
Test Suite: A suite of tests that can be run against the API to detect changes.
Clients: The API has been used successfully by at least 2 different teams, using API Documentation only.
Documentation: The API has a clean JavaDoc and reference documentation.
Support: The eXo Support team provides help on the code that uses this API, and fixes any reported bugs.
Compatibility X.Y.Z(+1): The compatibility between maintenance versions (X.Y.Z and X.Y.Z+1) is guaranteed. If a change appears between X.Y and X.Y+1, the eXo Support team will help by upgrading the code.
Compatibility X.Y(+1): The compatibility between minor versions (X.Y and X.Y+1) is guaranteed. If a change appears between X and X+1, the eXo Support team will help by upgrading the code.
Best Effort: We will provide assistance, but eXo cannot guarantee any specific result.
These APIs are provided to give an "early look" at what will be available in upcoming versions of the eXo Platform. These APIs are not final, but they can be used to start developing your application.
Provisional APIs are APIs close to being frozen, but that need a last look from users. They can be used by third-party developers for their own apps, with the knowledge that only a limited compatibility guarantee is offered.
Experimental APIs are APIs that are likely to change. They are published in order to get feedback from the community. These APIs have been tested successfully, but have not yet had enough feedback from developers.
Portlet API (JSR 168 and JSR 286): A Java standard that defines how to write portlets. This is the way to develop Java applications that are integrated into eXo Platform.
WSRP 1.0 on JBoss: A network protocol for integrating remote portlets into eXo Platform.
JAX-RS (JSR 311): A standard API that provides support for creating REST-like services.
JCR (JSR 170): A standard API that provides access to a content repository.
JCR Service Extensions : A set of APIs that provide extended functionalities for the JCR, such as observation, permissions, and access to a repository.
Java EE 6 : eXo Platform supports the Java EE 5 APIs, so you can develop applications using this standard.
Cache : An API used for data caching.
Event and Listener : An API for listening and sending events within eXo Platform.
Organization : An API and SPI for accessing user, group and membership information.
Portal Container Definition : This API is used to configure your portal.
Taxonomy : An API that allows you to organize your content.
Link Management : An API that provides a way to manage links when developing WCM features.
Publication Management : An API that provides different ways to manage the publication of content when developing WCM features.
WCM Composer : An API to get content shown in the website. The cache management is used in this service, and methods to update the content cache.
Template WCM : An API to provide views and dialogs to node types (system or document).
XML Configuration : A set of DTD for configuring eXo Platform.
OpenSocial 0.8 Gadget Specification : A standard that defines how to write gadgets and provide APIs. Gadgets are particularly useful for integrating external applications into eXo Platform.
CMIS : A standard API that gives access to the content repository via REST and SOAP Web services.
FTP : A standard protocol for exchanging documents.
OpenSocial 0.8 REST Protocol : A standard API for accessing the social graph and activity streams.
WebDAV : A standard protocol for exchanging document over HTTP.
UI Extensions: An API to plug new actions into the eXo Platform UI.