Data Types
Below is a list of all the types of object a connector might encounter.
Item
An Item represents a syncable entity. It has fields of its own as well as relations to other items.
type Item = {
// The fields and values of the item.
fields: Record<string, unknown>;
// The relations of the item.
relations: Relation[];
// The canonical path of the item.
canonicalPath?: string;
};
Relation
A Relation points to a Collection and describes the shape of the items it contains.
type Relation = {
// The main identifier of the relation.
// Can only contain numbers, letters, hyphens and underscores.
name: string;
// The relative path at which the relation data is available.
path: string;
// Optional list of parameters to be included in the request.
requestSchema?: { parameters: FieldSchema[] };
// The publicly visible label of the relation.
// e.g. "people"
label: string;
// Indicates whether or not we can search the collection to narrow down the returned data. Defaults to false.
searchable?: boolean;
// The shape of the items in this relation.
schema: {
// The publicly visible label of one item in this relation.
// e.g. "person"
label: string;
// Can we create items?
canCreateItem?: boolean;
// Can we update items?
canUpdateItem?: boolean;
// Can we delete items?
canDeleteItem?: boolean?
// Can we add fields to the schema?
canAddFields?: boolean?
// The shape of the fields.
fields: FieldSchema[],
// The meaning of the relation.
semantic?: RelationSemantic;
// Summaries of the relations expected to be found on these items.
relations?: RelationSummary[];
},
};
RelationSummary
A RelationSummary describes the common properties of a relation expected to be found on each item of a relation.
type RelationSummary = {
/**
* The main identifier of the relation.
*/
name: string;
/**
* The publicly visible label of the relation.
*/
label: string;
/**
* The semantic of the relation.
*/
semantic?: RelationSemantic;
/**
* The shape of the relation.
*/
schema: RelationSchema | "__self";
}
FieldSchema
A FieldSchema describes the shape of a field.
type FieldSchema = {
// The main identifier of the field.
// Can only contain numbers, letters, hyphens and underscores.
name: string;
// The type of the value field.
type: FieldValueType;
// The publicly visible label of the field.
label: string;
// Description of the field. For information purposes only.
info?: string;
// Category of the field. Used to group fields together when displayed.
category?: string;
// Whether the field returns an array. Defaults to false.
// An array is a non-paginated list of same-type values.
// For pagination, use a relation instead.
isArray?: boolean;
// Whether the field is read only.
readOnly?: boolean;
// Whether the field can be empty. Default to true.
nullable?: boolean;
// The meaning of the field.
semantic?: Semantic;
// The following properties are type specific. Each FieldValueType is free to
// ask for additional data depending on their needs. While they're flagged as
// being optional (?) in this shared interface, they could be required for the
// type to operate properly.
// When the type is "object", describe its schema.
fields?: FieldSchema[];
// When the type is "reference", describes the referenced relation.
reference?: Relation;
// When used within a request schema, some fields may decide to provide
// a list of potential options whose values are considered valid input.
// As an example, for a field of type "dateRange", such options may
// include points in time relative to today's date.
// e.g. "[{ label: "Last 30 days", value: "last_30_days" }, ... ]"
optionalValues?: { label: string; value: unknown }[];
};
FieldValueType
A FieldValueType determines the type of an item's value. The type represents a unique scalar value such as a string or an integer. For more complex types, use an Item instead.
enum FieldValueType {
// A complex field with fields and values of its own. The schema
// of these fields should be defined in the field's schema.
// e.g. { name: "foo" }
OBJECT = 'object',
// A reference to another existing item. The schema of this object
// should be defined in the field's schema. The value is represented
// as an ItemSummary.
// e.g. { path: "/users/1" }
REFERENCE = 'reference',
// A sequence of characters.
// e.g. "foo"
STRING = 'string',
// A valid email address, as described by IETF RFC 5321.
// e.g. "[email protected]"
EMAIL = 'email',
// A valid URL, including the scheme, the domain, and the TLD.
// e.g. "https://foo.bar/path?a=b
URL = 'url',
// Any non-floating point number between -9,007,199,254,740,991 and 9,007,199,254,740,991.
// e.g. 1234
INTEGER = 'integer',
// Any number between -9,007,199,254,740,991 and 9,007,199,254,740,991, including floating points.
// e.g. 1234.56
NUMBER = 'number',
// True or False.
// e.g. true
BOOLEAN = 'boolean',
// Rich-text with Markdown syntax.
RICH_TEXT_MARKDOWN = 'markdown',
// Rich-text with HTML syntax.
RICH_TEXT_HTML = 'html',
// ISO 8601 date format.
// e.g. "2023-11-05"
DATE = 'date',
// An object containing the start and the end of a date range, in ISO 8601 date format.
// When one of the two values is left empty, it is considered an open ended range.
// e.g. "2023-11-01/2023-11-05", or "2023-11-01/"
DATE_RANGE = 'dateRange',
// ISO 8601 date and time format.
// e.g. "2023-11-05T08:15:30.000-05:00".
DATETIME = 'datetime',
// An object containing the start and the end of a datetime range, in ISO 8601 date and time format.
// When one of the two values is left empty, it is considered an open ended range.
// e.g. "2023-11-01T08:00:00.000-05:00/2023-11-05T08:00:00.000-05:00", or "2023-11-01T08:00:00.000-05:00/"
DATETIME_RANGE = 'datetimeRange',
// Any type of binary data.
BLOB = 'blob',
// A duration, expressed as a number of seconds.
// It assumes 24 hours a day, 7 days a week.
// e.g. 180
DURATION = 'duration',
}
Semantic
A Semantic gives meaning to a Field in the Unito platform. A field with a specified semantic is expected to hold a certain type of value that can later be used by the consumers of the spec to better understand what that value means.
enum Semantic {
// Represents the desired display name of the item.
// Expected field value to be of type FieldValueType.STRING
DISPLAY_NAME = 'displayName',
// Represents the date at which the item has been created.
// Required for items to be synced.
// Expected field value to be of type FieldValueType.DATETIME
CREATED_AT = 'createdAt',
// Represents the date at which the item has last been updated.
// Required for items to be synced.
// Expected field value to be of type FieldValueType.DATETIME
UPDATED_AT = 'updatedAt',
// Represents the Provider URL at which the item is accessible.
// Expected field value to be of type FieldValueType.STRING
PROVIDER_URL = 'providerURL',
// Represents the textual description of the item. Could be used by
// syncing tools to append additional information, such a link to
// the other items with which this item is synchronized.
// Expected field value of type FieldValueType.STRING, RICH_TEXT_HTML, or RICH_TEXT_MARKDOWN
DESCRIPTION = 'description',
// Represents a user.
USER = 'user',
// Represents the parent of the item.
// Expected field value to be of type FieldValueType.REFERENCE
// When present, it tells us the list of parents of the item.
PARENT = 'parent',
}
Relation Semantic
A Relation Semantic gives meaning to a Relation in the Unito platform. A relation with a specified semantic is expected to hold a certain type of item that can later be used by the consumers of the spec for specific usage.
enum RelationSemantic {
// Represents a relation containing items that have the shape of comments.
// Comments are expected to comply with the following schema;
// - Exactly one field with a `DESCRIPTION` semantic
COMMENTS = 'comments',
// Represents a relation containing items that have the shape of users.
// Users are expected to comply with the following schema;
// - Exactly one field with a `DISPLAY_NAME` semantic
// - Zero or more fields of type `EMAIL`
USERS = 'users',
// Represents a relation containing items that have the shape of attachments.
// Attachments are expected to comply with the following schema;
// - Exactly one field of type `BLOB`
ATTACHMENTS = 'attachments',
// Represents a relation containing items that have the shape of subtasks.
// Subtasks are expected to use a self referencing schema through the use of the `__self` keyword.
SUBTASKS = 'subtasks',
}
OperatorType
An OperatorType represents an operator used in a filter.
enum OperatorType {
// Equality operator returns results for which the field is stricly equal to the provided value.
// e.g. status=active
EQUAL = '=',
// Non equality operator returns results for which the field is not stricly equal to the provided value.
// e.g. role!=admin
NOT_EQUAL = '!=',
// Greater than operator returns results for which the field is greater than the provided value.
// e.g. date>2022-01-01
GREATER_THAN = '>',
// Greater than or equal operator returns results for which the field is greater than or equal to provided value.
// e.g. date>=2022-01-01
GREATER_THAN_OR_EQUAL = '>=',
// Lesser than operator returns results for which the field is lesser than the provided value.
// e.g. date<2022-01-01
LESSER_THAN = '<',
// Lesser than or equal operator returns results for which the field is lesser or equal to the provided value.
// e.g. date<=2022-01-01
LESSER_THAN_OR_EQUAL = '<=',
// Include operator returns results for which the provided value is included in the field.
// e.g. description*=cat
INCLUDE = '*=',
// Exclude operator returns results for which the provided value is not included in the field.
// e.g. description!*=cat
EXCLUDE = '!*=',
// Start with operator returns results for which the field starts with the provided value.
// e.g. name^=A
START_WITH = '^=',
// End with operator returns results for which the field ends with the provided value.
// e.g. name$=Z
END_WITH = '$=',
// Is null operator returns results for which the field has a null value.
// e.g. filter=name!!
IS_NULL = '!!',
// Is not null operator returns results for which the field has a non null value.
// e.g. filter=name!
IS_NOT_NULL = '!',
}
Collection
A Collection represents a paginated list of ItemSummary available through a Relation. See Pagination's recipe page for more information.
type Collection = {
// Contextual information.
info: {
// Link to the next page.
nextPage?: string;
};
// List of item summaries.
data: ItemSummary[];
};
ItemSummary
An ItemSummary is a constituent of a collection. It links to an item, and can contain additional item information upon request — see the Select and Filters section for more details. Due to the dynamic nature of items, a path can optionally define additional parameters that will help define the items it links to — see the "Dynamic Items" section for more details.
type ItemSummary = {
// Link to this specific item.
path: string;
// Optional list of requested fields and their values.
fields?: Record<string, unknown>;
// Optional list of parameters to be included in the request.
requestSchema?: { parameters: FieldSchema[] };
// The canonical path of the item.
canonicalPath?: string;
};
CredentialAccount
A CredentialAccount describes the provider account associated to a credential (See X-Unito-Credentials
).
type CredentialAccount = {
// The native id of the provider account.
id: string;
// The display name of the provider account.
displayName: string;
// The emails associated with the provider account.
emails: string[];
// Partition can be used to divide data into different buckets.
partition?: string;
};
WebhookSubscriptionRequestPayload
A WebhookSubscriptionRequestPayload describes the shape of the request on the "webhook subscription" endpoint.
type WebhookSubscriptionRequestPayload = {
// The path of the item to which the subscription belongs.
itemPath: string;
// The target URL at which events should be sent.
targetUrl: string;
// The desired action to be applied to the subscription.
action: 'start' | 'stop';
};
WebhookParseRequestPayload
A WebhookParseRequestPayload describes the shape of the request on the "parse webhook" endpoint.
type WebhookParseRequestPayload = {
// The partition data for which this webhook was received.
partition?: string;
// The raw headers sent by the provider.
headers: Record<string, string>;
// The raw payload sent by the provider.
payload: string;
// The full URL, including query params, on which this webhook was received.
url: string;
};
WebhookParseResponsePayload
A WebhookParseResponsePayload describes the shape of the response on the "parse webhook" endpoint.
type WebhookParseResponsePayload = {
// The path of the item targetted by this event.
itemPath: string;
// The date at which the event took place, expressed as an ISO 8601 string.
// e.g "2023-11-05T08:15:30.000-05:00"
date: string;
// The item's relations impacted by this event.
impactedRelations: {
// The name of the relation.
name: string;
// The list of specific items impacted by this event.
impactedItems: WebhookParseResponsePayload[];
}[];
};
WebhookAcknowledgeResponsePayload
A WebhookAcknowledgeResponsePayload describes the shape of the response on the "acknowledge webhook" endpoint.
type WebhookAcknowledgeResponsePayload = {
// The status code that should be returned to the provider.
statusCode: number;
// The headers that should be returned to the provider.
headers?: Record<string, string | string[]>;
// The payload that should be returned to the provider.
payload?: string;
};
Error
An error is used when an operation doesn't succeed.
type Error = {
// Specific error code. Usually the HTTP response code.
code: string;
// Raw error message.
message: string;
// Free-form key-value store. For logging/debugging purposes.
details?: Record<string, string>;
// Original error as returned by the provider.
originalError?: Error;
};