Custom Data Integration
Last updated
Was this helpful?
Last updated
Was this helpful?
Custom data integration allows you to create custom resource schemas and collect custom data in addition to existing resources.
To add your custom data integration, first, you need to create a custom schema group, custom schema, and then create the integration (consequently, in this order.) Follow the instructions below for details.
Schema groups have unique names and prefixes. The prefix will be used as a prefix on your custom resources.
Before adding a custom schema and a custom data integration, a valid custom schema group should be created. To do that, go to Settings → Custom Schemas (under the Integrations section).
Then click the Add Group, and fill in the related sections.
After creating a group, then we can create a custom schema. To do that, go to Settings → Custom Schemas (under the Integrations section).
Then click the Add Schema, and fill in the related sections.
Resmo uses JSON Schema (for more information: JSON Schema) for creating a custom resource schema.
Support for only the 2020-12 version (JSON Schema 2020-12 Release Notes)
It cannot be empty or any type other than an object because Resmo only supports object(a valid map) structure for resources.
id
: the path of the id field, which cannot be empty, must be a string. This information will be used unique identifier of the resource.
name
: the path of the name field, optional, must be a string. This information will be used to display the purpose of the resource on Resmo.
importantFields
: paths of the important fields, optional, list of paths. This information will be used for display purposes as well on Resmo.
Example:
1"resmo": { 2 "id": "employeeId", 3 "name": "$.employee.username", 4 "importantFields": [ 5 "employeeId", 6 "$.employee.email", 7 "active" 8 ] 9}
If the schema is valid, Resmo services put unevaluatedProperties
property to the root path of the schema to avoid sending unevaluated properties. (extra/unknown properties)
After the group and the schema is created, you can now create an integration to attach them. To do that, go to Settings → Integrations (under the Integrations section) and Add Integration.
Select Custom Data integration from the available integrations list.
After the integration is created with valid groups and schemas, you can send your resource changes with HTTP requests.
In this part, you can check out example schema, and resource payloads in:
https://YOUR_DOMAIN.resmo.app/integration/custom-data/event/YOUR_TABLE_NAME_HERE
→ Set your domain name and requested table name. (which is named as Table Name on the schema)
?groupKey=YOUR_GROUP_KEY_HERE
→ (OPTIONAL) For grouping resources, for example, you have multiple resources with the same identifier, but those belong to another department/company etc., you can set groupKey. To see more detail about groupKey you can check _meta
of the resource.
&event=YOUR_EVENT_NAME_HERE
→ (OPTIONAL) Event name of the HTTP request; you can see it on the changes history.
&actor=YOUR_ACTOR_HERE
→ (OPTIONAL) Actor name of the HTTP request; you can see it on the changes history as well. it should be a JSON.
‘X-Ingest-Key: YOUR_INTEGRATION_INGEST_KEY_HERE'
→ Ingest Key of the integration.
--data 'PAYLOAD_HERE'
→ Resource payload
If there is no resource with id (+ groupKey) information before then, there will be a new resource!
If there is an existing resource, this request will be considered an update request. For the update request, if the current resource is the same, then the request will be ignored.
To remove a resource, please have a look at deleting a resource section.
Be sure that the requested payload is valid with the JSON schema
Payload with unknown fields will not be processed
Size could not be bigger than 1MB for each resource
The Actor field can be up to 1000 characters, and the event and groupKey fields can be up to 100 characters.
Payloads without id field information will be rejected.
https://YOUR_DOMAIN.resmo.app/integration/custom-data/bulk-event/YOUR_TABLE_NAME_HERE
→ Set your domain name and requested table name. (which is named as Table Name on the schema)
?groupKey=YOUR_GROUP_KEY_HERE
→ (OPTIONAL) For grouping resources, for example, you have multiple resources with the same identifier, but those belong to another department/company, etc., you can set groupKey. To see more detail about groupKey you can check _meta
of the resource.
&event=YOUR_EVENT_NAME_HERE
→ (OPTIONAL) Event name of the HTTP request; you can see it on the changes history.
&actor=YOUR_ACTOR_HERE
→ (OPTIONAL) Actor name of the HTTP request; you can see it on changes history as well. it should be a JSON.
‘X-Ingest-Key: YOUR_INTEGRATION_INGEST_KEY_HERE'
→ Ingest Key of the integration.
--data 'LIST-OF-PAYLOAD-HERE'
→ List of resources
This endpoint is for sending a bunch of resources at once.
If there is no resource with id (+ groupKey) information before then, there will be a new resource!
If there is an existing resource, it will be updated. Ignored if the resource payload is the same.
Bulk does not support patches; it needs every resource in the request. It means if there is a missing resource in the payload, then it will be removed.
For example, in the screenshot, three resources were added for _directory_employee
with IDs a, b, c with one bulk request.
After then, there will be another bulk request with a, b, d resources, and c is missing and a, b updated.
As a result, c is removed, a and b are updated, and d is added as a resource.
Same validations with Sending a resource to Resmo
The size cannot exceed 4MB for all resources in one request.
https://YOUR_DOMAIN.resmo.app/integration/custom-data/bulk-event/YOUR_TABLE_NAME_HERE
→ Set your domain name and requested table name. (which is named as Table Name on the schema)
?resourceIds=IDS
→ Requested resource IDs'
&groupKey=YOUR_GROUP_KEY_HERE
→ (OPTIONAL) For grouping resources, for example, if you have multiple resources with the same identifier, but those belong to another department/company, etc., you can set groupKey. To see more detail about groupKey you can check _meta
of the resource.
&event=YOUR_EVENT_NAME_HERE
→ (OPTIONAL) Event name of the HTTP request; you can see it on the changes history.
&actor=YOUR_ACTOR_HERE
→ (OPTIONAL) Actor name of the HTTP request; you can see it on changes history as well. it should be a JSON.
‘X-Ingest-Key: YOUR_INTEGRATION_INGEST_KEY_HERE'
→ Ingest Key of the integration.
If there is no resource with ID (+ groupKey) information, then it will be ignored.
There must be a resmo
property inside of the schema’s root. It can contain id
, name
(optional), importantFields
(optional). Those paths support json-path (JSONPath - XPath for JSON ):