The DP RESTful API is designed to allow programmatic access to various DP data such as projects, word lists, and statistics.
The API is enabled by default because some UI features, like the Page Browser, require it.
While disabling the API will break these features, you can still do so by
updating the API_ENABLE
setting in your configuration.sh
file and
re-configuring your site.
API_ENABLE
- if set toFALSE
the API is disabled.
While not required for the DP UI, for external users it is also highly
recommended that you update your web server to rewrite requests for /api/
to api/index.php?url=
. This will enable access to URLs like:
https://www.example.com/api/v1/projects/
Instead of:
https://www.example.com/c/api/index.php?url=v1/projects/
This can be achieved by adding a stanza such as this one to your Apache config:
RewriteEngine On
RewriteRule ^/api/(.*)$ %{DOCUMENT_ROOT}/c/api/index.php?url=$1 [L,QSA]
API access is limited to individuals with API keys or valid PHP session keys. Both are associated with individual users and the API calls are restricted to the same information as the user presenting the keys. Said another way, a user can only access and change information via the API that they can via the UI.
To enable an API key for a user, add a 32-character GUID to the user's
api_key
column in the database. The format of this field is not enforced, any
32-character string will do.
PHP session keys allow the DP UI to make API calls for loading data. Any logged-in user can therefore access the API using their PHP session information. No configuration change is required to enable API access over PHP sessions.
It is highly recommended that you only provide API access over https to ensure that 3rd parties don't obtain API keys from the requests.
API requests can be rate limited to help prevent the site from being
overwhelmed. To use Rate Limiting, you must have the PHP memcached module
installed and a local memcached process running and accessible via localhost.
If rate limiting is enabled and memcached is not accessible, API requests will
fail and an error will be logged to php_errors
.
Three settings in configuration.sh
control limiting:
_API_RATE_LIMIT
- enables or disables rate limiting._API_RATE_LIMIT_REQUESTS_PER_WINDOW
- the number of API requests that are allowed per given window._API_RATE_LIMIT_SECONDS_IN_WINDOW
- the number of seconds within a given window.