External API
Introduction
The external API inside Nextcloud allows third party developers to access data provided by Nextcloud apps. Nextcloud follows the Open Collaboration Services specification.
Usage
Registering methods
Methods are registered inside the appinfo/routes.php
by returning an array holding the endpoint meta data.
<?php
return [
'ocs' => [
// Apps
['name' => 'Bar#getFoo', 'url' => '/foobar', 'verb' => 'GET'],
],
];
Returning data
Once the API backend has matched your URL, your callable function as defined in BarController::getFoo will be executed. The AppFramework will make sure that send parameters are provided to the method based on its declaration.
Be sure to extend the OCP\AppFramework\OCSController
from the AppFramework. Your functions then should returns a OCP\AppFramework\Http\DataResponse
. The AppFramework will then take care formatting the response properly.
Exceptions
To throw an exception to the user in the OCS response. You can throw an OCP\AppFramework\OCS\OCSException
. You can set the message and code.
There are 3 commonly used exceptions already available:
OCSBadRequestException
OCSForbiddenException
OCSNotFoundException
Authentication & basics
The requests to the OCS endpoint often have to be authenticated.
curl -u user:password https://example.com/ocs/v2.php/apps/yourapp/foobar
Output
The output defaults to XML. If you want to get JSON append this to the URL:
?format=json
Or set the proper Accept header:
Accept: application/json
Output from the application is wrapped inside a data element:
XML:
<?xml version="1.0"?>
<ocs>
<meta>
<status>ok</status>
<statuscode>100</statuscode>
<message/>
</meta>
<data>
<!-- data here -->
</data>
</ocs>
JSON:
{
"ocs": {
"meta": {
"status": "ok",
"statuscode": 100,
"message": null
},
"data": {
// data here
}
}
}
Statuscodes
The statuscode can be any of the following numbers:
- 100 - successful
- 996 - server error
- 997 - not authorized
- 998 - not found
- 999 - unknown error
Changing API and backwards compatibility
We aim to keep our API as stable as possible to avoid breaking third-party apps. Before an API is allowed to be removed, it should be marked as deprecated for at least 2 years (6 Nextcloud releases) before it gets removed.
Changing the API should be discussed in a github issue in our server repo. A pull request is most welcome.