Retrieve the App Data Model
It is sometimes necessary to know the structure of the data that will be returned by the JourneyApps API. For example, knowing which fields to expect for certain objects.
This API function allows you to retrieve a structured representation of your app's Data Model, exactly as defined in schema.xml within OXIDE.
/api/v4/
backend-deployment-id
/datamodel.json
GET
Parameters
This API function does not take any parameters (except for standard ETag functionality — please see below).
Response
The response will contain a list of the object types in the particular app's Data Model, with a list of fields of each object type. Relationships of the object types are also included.
The Data Model is a representation of the fields defined by the developer of the app in the app's Data Model. The JourneyApps API will also return some metadata in addition to these fields.
For example updated_at
and id
will be returned in JourneyApps API responses (see Retrieving all Objects).
The HTTP headers for the response also include an ETag header which allows you to keep track of versions of the Data Model. Whenever changes are made to the app's Data Model, the hash in the ETag header will change. You can include this ETag hash value with the If-None-Match
header in subsequent calls to the datamodel
API function. If the Data Model for the app hasn't changed, a "304 Not Modified" response code will be returned.
The response also contains a field called datamodel_hash
, identifying the current version of the data model. This matches the value in the oplog.json
call.
Example
BASE-URL
The below examples contain a BASE-URL
placeholder. Please refer to the HTTP Endpoints section to get the base URL relevant to your deployment.
Response:
Last updated