Compliance API
Compliance API Reference
Note: This page is primarily intended for developers who will be writing applications that will use DataTrails for provenance. If you are looking for a simple way to test our API you might prefer our Postman collection, the YAML runner or the Developers section of the web UI.
Additional YAML examples can be found in the articles in the Overview section.
Compliance API Examples
Create the bearer_token and store in a file in a secure local directory with 0600 permissions.
Types of Compliance Policies
Compliance posture is measured against user-defined rule sets called Compliance Policies.
Compliance Policies are created once and then Assets can be tested against them at any point in time.
For instance, a policy might state that “Maintenance Alarm Events must be addressed with a Maintenance Report Event recorded in 72 hours”.
This creates a Compliance Policy object in the system against which any Asset can be tested as needed.
DataTrails allows users to define Compliance Policies of the following types:
COMPLIANCE_SINCE
This Compliance Policy checks if the time since the last occurrence of a specific Event type has elapsed a specified threshold.
For example “Time since last Maintenance must be less than 72 hours”:
{
"compliance_type": "COMPLIANCE_SINCE",
"description": "Maintenance should be performed every 72h",
"display_name": "Regular Maintenance",
"asset_filter": [
{ "or": ["attributes.arc_home_location_identity=locations/5eef2b71-35c1-4376-a166-6c64bfa72f4b"]}
],
"event_display_type": "Maintenance Performed",
"time_period_seconds": "259200"
}
Attribute | Description |
---|---|
event_display_type | Type of Event we want to check with this Compliance Policy |
time_period_seconds | The maximum amount of time allowed since a specified Event type last occurred, in seconds |
COMPLIANCE_CURRENT_OUTSTANDING
This Compliance Policy will only pass if there is an associated closing event addressing a specified outstanding Event.
To correlate Events, define the attribute arc_correlation_value
in the Event attributes and set it to the same value on each pair of Events that are to be associated.
Note: To properly track and assess Events, thearc_correlation_value
should be unique to each pair of Events.
For example, defining pairs of Events like Maintenance Request
and Maintenance Performed
:
{
"compliance_type": "COMPLIANCE_CURRENT_OUTSTANDING",
"description": "There should be no outstanding Maintenance Requests",
"display_name": "Outstanding Maintenance Requests",
"asset_filter": [
{ "or": ["attributes.arc_home_location_identity=locations/5eef2b71-35c1-4376-a166-6c64bfa72f4b"]}
],
"event_display_type": "Maintenance Request",
"closing_event_display_type": "Maintenance Performed"
}
Attribute | Description |
---|---|
event_display_type | Type of Event that should be addressed by the Event defined in closing_event_display_type |
closing_event_display_type | Type of Event addressing the Event defined in event_display_type |
COMPLIANCE_PERIOD_OUTSTANDING
This Compliance Policy will only pass if the time between a pair of correlated Events did not exceed the defined threshold.
To correlate Events, define the attribute arc_correlation_value
in the Event attributes and set it to the same value on each pair of Events that are to be associated.
Note: To properly track and assess Events, thearc_correlation_value
should be unique to each pair of Events.
For example, a policy checking that the time between Maintenance Request
and Maintenance Performed
Events does not exceed the maximum 72 hours:
{
"compliance_type": "COMPLIANCE_PERIOD_OUTSTANDING",
"description": "There should be no outstanding Maintenance Requests",
"display_name": "Outstanding Maintenance Requests",
"asset_filter": [
{ "or": ["attributes.arc_home_location_identity=locations/5eef2b71-35c1-4376-a166-6c64bfa72f4b"]}
],
"event_display_type": "Maintenance Request",
"closing_event_display_type": "Maintenance Performed",
"time_period_seconds": "259200"
}
Attribute | Description |
---|---|
event_display_type | Type of Event that should be addressed by the Event defined in closing_event_display_type |
closing_event_display_type | Type of Event addressing the Event defined in event_display_type |
time_period_seconds | Maximum amount of time that can elapse between associated Events, in seconds |
COMPLIANCE_DYNAMIC_TOLERANCE
This Compliance Policy will only pass if the time between correlated Events is not excessively different to the observed average normal duration for similar Events.
To correlate Events, define the attribute arc_correlation_value
in the Event attributes and set it to the same value on each pair of Events that are to be associated.
Note: To properly track and assess Events, thearc_correlation_value
should be unique to each pair of Events.
For example, a policy checking that the time between Maintenance Request
and Maintenance Performed
Events in the last week does not exceed a variability of 0.5 standard deviations around the mean:
{
"compliance_type": "COMPLIANCE_DYNAMIC_TOLERANCE",
"description": "Average time between Maintenance Requested/Performed",
"display_name": "Outlying Maintenance Requests",
"asset_filter": [
{ "or": ["attributes.arc_home_location_identity=locations/5eef2b71-35c1-4376-a166-6c64bfa72f4b"]}
],
"event_display_type": "Maintenance Request",
"closing_event_display_type": "Maintenance Performed",
"dynamic_window": 604800,
"dynamic_variability": 0.5
}
Attribute | Description |
---|---|
event_display_type | Type of Event that should be addressed by the Event defined in closing_event_display_type |
closing_event_display_type | Type of Event addressing the Event defined in event_display_type |
dynamic_window | Number of seconds in the past - only Events in this time window are considered |
dynamic_variability | Exceeding this number of standard deviations from the mean will cause compliance to fail for a particular pair of matching Events |
COMPLIANCE_RICHNESS
This Compliance Policy will only pass if attributes are within expected bounds or otherwise meet defined conditions.
An assertion is comprised of: an attribute name, a comparison value and an operator to compare with; for example rad<7
.
The operator can be one of six relational operators: equal to, not equal to, greater than, less than, greater than or equal to, less than or equal to; [=|!=|>|<|>=|<=]
.
Assertions are comprised of two lists, an inner list and outer list. The inner list states that, if any of the assertions pass, then the list is compliant (OR
logic). For example:
{“or”: [“rad<7”, “rad=10”]}.
The outer list states that, all inner lists need to be compliant in order for the policy to be compliant (AND
logic).
Compliance is a signal, not a perfect answer. Therefore equivalence of floats is exact, not approximate.
{
"compliance_type": "COMPLIANCE_RICHNESS",
"description": "Rad level is less than 7",
"display_name": "Rad limit",
"asset_filter": [
{ "or": ["attributes.arc_home_location_identity=locations/5eef2b71-35c1-4376-a166-6c64bfa72f4b"]}
],
"richness_assertions": [
{ "or": ["rad<7"]}
],
}
Attribute | Description |
---|---|
richness_assertions | The assertions to be made, against Asset attributes, to check if the Asset is compliant. |
Compliance Policy Creation
Create a Compliance Policy with:
curl -v -X POST \
-H "@$HOME/.datatrails/bearer-token.txt" \
-H "Content-type: application/json" \
-d "@/path/to/jsonfile" \
https://app.datatrails.ai/archivist/v1/compliance_policies
Using data from /path/to/jsonfile
in the format described in
Types of Compliance Policies.
Sample response:
{
"identity": "compliance_policies/6a951b62-0a26-4c22-a886-1082297b063b",
"compliance_type": "COMPLIANCE_CURRENT_OUTSTANDING",
"description": "There should be no outstanding Maintenance Requests",
"display_name": "Outstanding Maintenance Requests",
"asset_filter": [
{ "or": ["attributes.arc_home_location_identity=locations/5eef2b71-35c1-4376-a166-6c64bfa72f4b"]}
],
"event_display_type": "Maintenance Request",
"closing_event_display_type": "Maintenance Performed",
"time_period_seconds": "259200"
}
Checking Compliance
The compliance v1 endpoint reports on the status of an Asset’s compliance with Compliance Policies.
Query the endpoint:
curl -v -X GET \
-H "@$HOME/.datatrails/bearer-token.txt" \
https://app.datatrails.ai/archivist/v1/compliance/assets/6a951b62-0a26-4c22-a886-1082297b063b
or if determining compliance at some historical date:
curl -v -X GET \
-H "@$HOME/.datatrails/bearer-token.txt" \
"https://app.datatrails.ai/archivist/v1/compliance/assets/6a951b62-0a26-4c22-a886-1082297b063b?compliant_at=2019-11-27T14:44:19Z"
The response is:
{
"compliant": true,
"compliance": [
{
"compliance_policy_identity": "compliance_policies/0000-0000-000000000-00000000",
"compliant": true,
"reason": ""
}
],
"compliant_at": "2019-11-27T14:44:19Z"
}
Compliance OpenAPI Docs
API to manage Compliance.
get /archivist/v1/compliance/assets/archivist/v1/compliance/assets/{uuid}
List all compliance status relevant to an asset
Description:
{
"compliance": [
{
"compliance_policy_identity": "compliance_policies/0000-0000-000000000-00000000",
"compliant": false
}
],
"compliant": false,
"compliant_at": "2019-11-27T14:44:19Z"
}
Response Parameter | Type | Description |
---|---|---|
compliance | array | simple compliance status against a compliance policy. |
compliant | boolean | overall compliance status for the asset |
compliant_at | string | time at which compliance is determined |
next_page_token | string | Token to retrieve the next page of results or empty if there are none. |
Responses | Description |
---|---|
200 | A successful response. |
206 | The number of compliance statements exceeds the servers limit. |
401 | Returned when the user is not authenticated to the system. |
403 | Returned when the user is not authorized to access the requested resource. |
404 | Returned when the no asset with the provided id can be found. |
429 | Returned when a user exceeds their subscription’s rate limit for requests. |
API to manage Compliance Policies.
get /archivist/v1/compliance_policies/archivist/v1/compliance_policies
List Compliance Policies
Description: Retrieves a list of Compliance Policies
{
"compliance_policies": [
{
"asset_filter": [
{
"or": [
"attributes.arc_location_identity:locations/5eef2b71-35c1-4376-a166-6c64bfa72f4b"
]
}
],
"compliance_type": "COMPLIANCE_SINCE",
"description": "sample compliance policy",
"display_name": "my compliance policy",
"event_display_type": "tracked event",
"identity": "compliance_policies/463fab3a-bae5-4349-8f76-f6454da20c9d",
"time_period_seconds": 86400
}
],
"next_page_token": "NDYzZmFiM2EtYmFlNS00MzQ5LThmNzYtZjY0NTRkYTIwYzlkCg=="
}
Response Parameter | Type | Description |
---|---|---|
compliance_policies | array | compliance policy |
next_page_token | string |
Responses | Description |
---|---|
200 | A successful response. |
401 | Returned when the user is not authenticated to the system. |
403 | Returned when the user is not authorized to access the requested resource. |
404 | Returned when the asset with the id does not exist. |
429 | Returned when a user exceeds their subscription’s rate limit for requests. |
post /archivist/v1/compliance_policies/archivist/v1/compliance_policies
Create a Compliance Policy
Description: Creates a Compliance Policy
{
"asset_filter": [
{
"or": [
"attributes.arc_location_identity:locations/5eef2b71-35c1-4376-a166-6c64bfa72f4b"
]
}
],
"compliance_type": "COMPLIANCE_SINCE",
"description": "Ensure Maintenance is performed daily",
"display_name": "Daily Maintenance",
"event_display_type": "Maintenance Performed",
"time_period_seconds": 86800
}
Parameter | Type | Description |
---|---|---|
asset_filter | array | Filter |
closing_event_display_type | string | this is the correlated event type |
compliance_type | policy type | |
description | string | Customer description of the compliance policy. |
display_name | string | display name |
dynamic_variability | number | number of standard deviations - required for DYNAMIC_TOLERANCE |
dynamic_window | string | valid period for policy - required for DYNAMIC_TOLERANCE |
event_display_type | string | this is the target event_display_type - always required |
richness_assertions | array | Filter |
time_period_seconds | string | time delta - required for SINCE and PERIOD_OUTSTANDING |
{
"asset_filter": [
{
"or": [
"attributes.arc_location_identity:locations/5eef2b71-35c1-4376-a166-6c64bfa72f4b"
]
}
],
"compliance_type": "COMPLIANCE_SINCE",
"description": "Ensure Maintenance is performed daily",
"display_name": "Daily Maintenance",
"event_display_type": "Maintenance Performed",
"identity": "compliance_policies/463fab3a-bae5-4349-8f76-f6454da20c9d",
"time_period_seconds": 86800
}
Response Parameter | Type | Description |
---|---|---|
asset_filter | array | Filter |
closing_event_display_type | string | |
compliance_type | ||
description | string | |
display_name | string | |
dynamic_variability | number | |
dynamic_window | string | |
event_display_type | string | |
identity | string | |
richness_assertions | array | Filter |
time_period_seconds | string |
Responses | Description |
---|---|
200 | A successful response. |
401 | Returned when the user is not authenticated to the system. |
402 | Returned when the user’s quota of compliance policies has been reached. |
403 | Returned when the user is not authorized to access the requested resource. |
404 | Returned when the asset with the id does not exist. |
429 | Returned when a user exceeds their subscription’s rate limit for requests. |
delete /archivist/v1/compliance_policies/archivist/v1/compliance_policies/{uuid}
Delete a Compliance Policy
Description: Deletes a Compliance Policy
{
"asset_filter": [
{
"or": [
"attributes.arc_location_identity:locations/5eef2b71-35c1-4376-a166-6c64bfa72f4b"
]
}
],
"compliance_type": "COMPLIANCE_SINCE",
"description": "Ensure Maintenance is performed daily",
"display_name": "Daily Maintenance",
"event_display_type": "Maintenance Performed",
"identity": "compliance_policies/463fab3a-bae5-4349-8f76-f6454da20c9d",
"time_period_seconds": 86800
}
Response Parameter | Type | Description |
---|---|---|
asset_filter | array | Filter |
closing_event_display_type | string | |
compliance_type | ||
description | string | |
display_name | string | |
dynamic_variability | number | |
dynamic_window | string | |
event_display_type | string | |
identity | string | |
richness_assertions | array | Filter |
time_period_seconds | string |
Responses | Description |
---|---|
200 | A successful response. |
401 | Returned when the user is not authenticated to the system. |
403 | Returned when the user is not authorized to access the requested resource. |
404 | Returned when the asset with the id does not exist. |
429 | Returned when a user exceeds their subscription’s rate limit for requests. |
get /archivist/v1/compliance_policies/archivist/v1/compliance_policies/{uuid}
Retrieves a Compliance Policy
Description: Retrieves a specific Compliance Policy
{
"asset_filter": [
{
"or": [
"attributes.arc_location_identity:locations/5eef2b71-35c1-4376-a166-6c64bfa72f4b"
]
}
],
"compliance_type": "COMPLIANCE_SINCE",
"description": "Ensure Maintenance is performed daily",
"display_name": "Daily Maintenance",
"event_display_type": "Maintenance Performed",
"identity": "compliance_policies/463fab3a-bae5-4349-8f76-f6454da20c9d",
"time_period_seconds": 86800
}
Response Parameter | Type | Description |
---|---|---|
asset_filter | array | Filter |
closing_event_display_type | string | |
compliance_type | ||
description | string | |
display_name | string | |
dynamic_variability | number | |
dynamic_window | string | |
event_display_type | string | |
identity | string | |
richness_assertions | array | Filter |
time_period_seconds | string |
Responses | Description |
---|---|
200 | A successful response. |
401 | Returned when the user is not authenticated to the system. |
403 | Returned when the user is not authorized to access the requested resource. |
404 | Returned when the asset with the id does not exist. |
429 | Returned when a user exceeds their subscription’s rate limit for requests. |