SymphonyData Discovery REST API Overview
This applies to: Visual Data Discovery
The Symphony Data Discovery REST API provides methods for retrieving, updating, and deleting Symphony metadata pertaining to accounts, connections, and users.
API documentation is provided with your Symphony installation at this link: <symphony-URL>/discovery/swagger-ui.html
.
experimental
in the Swagger documentation we provide. These endpoints are in the early stages of design and are subject to change. We make no commitment to their stability and may remove them without notice. These experimental endpoints are not recommended for use in production.
This topic describes the following REST API topics:
- Authentication
- Version Compatibility
- HATEOAS Architecture
- API Entry Point
- The /api/ Path
- Optimistic Locking on PATCH Calls
- Reference Documentation
Authentication
The API currently uses basic access authentication. Most actions require admin-level access to the particular account manipulated using the API.
Version Compatibility
Each version of the API maintains backward compatibility with previous versions. The HTTP Accepts/Content-type header is used to specify the version for the resources that are produced and used by the API. When sending data to or receiving data from the API, you must use the appropriate HTTP header.
When working with the API, you should explicitly set the version of the API that you want to use. For example, in cURL requests, you would include the --header
parameter as shown below.
curl --header "Content-type: application/vnd.composer.v3+json" ...
# Consuming data
curl --header "Accept: application/vnd.composer.v3+json,application/vnd.composer+json" ...
To ensure you always use the latest version of Symphony, use the generic media type: application/vnd.composer+json
.
The current API media type version will be sent as a header, X-Composer-Media-Type
, in the response to every API request.
The rule for specifying media types is simple. Always include the generic media type application/vnd.composer+json
and, if you specify a particular version, always put it first. For example:
- Correct:
application/vnd.composer.v3+json,application/vnd.composer+json
- Incorrect:
application/vnd.composer+json, application/vnd.composer.v3+json
HATEOAS Architecture
The Symphony API implements the HATEOAS architectural pattern. Most resources returned by the API have a links
element. The links elements is an array of objects, each with two properties:
rel
: short description of how this link relates to the parent objecthref
: the actual link value
Every resource will at least have a rel: "self"
link, which is the canonical reference to that object. You can use the other links to explore the relations of a given object, for example, the users in an account or the sources tied to a connection.
API Entry Point
The initial entry point to the API is http://<host>:<port>/<context>/api
. For example:
http://localhost:8080/
discovery/api
This URL points to the root API resources that you can use to browse through the API.
The /api/ Path
Some functions of the Symphony client application call APIs using a /api/
path. Except where noted in Symphony's developer documentation, endpoints that use the
/api/
path are for Symphony's internal use only.
APIs on the /api/
path that are safe to use include, for example, the /api/sources/key
endpoint.
Optimistic Locking on PATCH Calls
API data source PATCH calls use optimistic locking to ensure the PATCH is applied to the most recent records. A version
parameter is used in these calls to track the version counter number. If this counter is not incremented in the payload of the call or if it is in error, the PATCH call will fail with an error similar to this:
"error": "INTERNAL_ERROR"
The exact and correct version counter number must be used or the API call will fail. For example, if you just submitted a PATCH call using version 8 and your next PATCH call uses version 10, you will receive an error response.
Consequently, prior to any PATCH call, be sure you do one of the following things:
Perform a GET call immediately prior to the PATCH call to retrieve the latest version counter number. This is the recommended approach.
If no changes have been made using the UI, and you can safely remember the version counter number of the previous call after every successful PATCH call, simply increment the version counter number in your newest PATCH call.
Reference Documentation
Symphony maintains Swagger-based reference materials for the data discovery REST APIs. In this testing environment, you can experiment with the APIs features.
API documentation is provided with your Symphony installation at this link: <symphony-URL>/discovery/swagger-ui.html
.
experimental
in the Swagger documentation we provide. These endpoints are in the early stages of design and are subject to change. We make no commitment to their stability and may remove them without notice. These experimental endpoints are not recommended for use in production.
Comments
0 comments
Please sign in to leave a comment.