openapi: 3.0.4 info: title: Listrak Cross Channel REST API description: "# Introduction\n\nWelcome to the Listrak Cross Channel REST\ \ API!\n\nOur API allows developers to integrate with Listrak's application.\ \ It enables the seamless automation of a broad set of functionality, ranging\ \ from basic tasks to complex processes.\n\nWe aim to provide comprehensive documentation\ \ coverage of our API's capabilities. Each resource and method is described in\ \ detail with implementation notes, descriptions of parameters, headers, return\ \ values, and code samples to aid in development.\n\n# Versioning\n\nThe API version\ \ is denoted in the URI. This API's base URI is: v1\n\nThe API version will be\ \ incremented if breaking changes are introduced. Breaking changes may include:\n\ \n- Addition of required headers, parameters, or model fields to a current route\n\ - Alterations that would result in currently valid requests failing, or performing\ \ unexpectedly\n\nChanges that are not considered breaking may include:\n\n- Addition\ \ of new model fields\n- Addition of new routes\n- Addition of new response headers\n\ - Any alteration to a route that is marked as In Development\n\ \n# Feedback\n\nWe are actively seeking feedback in the following areas:\n- Code\ \ samples\n- Response examples\n- Resource and field descriptions\n\nPlease provide\ \ your feedback to us at restapifeedback@listrak.com.\n\n# Integration Setup\n\ To enable API access, **you must create an _Integration_** on the _Integrations_\ \ page. In the Listrak application left menu, go to: Integrations → Integration\ \ Management.\n\nPlease specify integration type `Cross Channel` for your integration.\n\ \nMake sure to securely store a copy of your _Client ID_ and _Client Secret_.\ \ These values will be needed to authenticate with the API. For your security,\ \ the _Client Secret_ cannot be retrieved if it is lost.\n\n# Status Codes\n\n\ | Status Code | Status | Description |\n| --- | --- | --- |\n| 200 | OK | The\ \ request succeeded. |\n| 201 | Created | A new resource has been created. |\n\ | 400 | Bad Request | Your request is malformed or invalid. |\n| 401 | Unauthorized\ \ | Authentication is required. |\n| 404 | Not Found | The resource does not exist.\ \ |\n| 405 | Method Not Allowed | The route does not support the requested method.\ \ |\n| 415 | Unsupported Media Type | Please use a `Content-Type` of `application/json`.\ \ |\n| 500 | Internal Server Error | An unexpected error occurred. Our development\ \ team has been notified. |\n\n# Parameters\n\n## Route Parameters\n\nResource\ \ identifiers are specified in the route. For example, in the route `/Resource/{resourceId}`,\ \ `resourceId` is a route parameter. In this example, if you wish to interact\ \ with Resource #123, its route would be `/Resource/123`.\n\n## Query Parameters\n\ \nSome routes support additional query parameters; for example, some resources\ \ support query parameters relating to paging. Supported query parameters are\ \ described in their respective documentation areas.\n\n## Request Body\n\nRequest\ \ bodies are required for most `POST` and `PUT` requests. Please use a `Content-Type`\ \ of `application/json` and provide a JSON object in your request body.\n\n# Authentication\n\ Authentication is accomplished using OAuth 2.0. After successful authentication,\ \ your token should be included with every request using the Bearer scheme; specifically,\ \ you should set your Authorization header value to Bearer (Your token value)\ \ in each request.\n\nYou may request a token by making a POST request to our\ \ token endpoint at https://auth.listrak.com/OAuth2/Token. \n\nThe request should\ \ have a Content-Type of x-www-form-urlencoded, and the request body should include\ \ a grant_type of client_credentials, your client_id, and your client_secret.\ \ Here is an example of a valid request:\n\n**POST /OAuth2/Token**\n\n**Body**\n\ \nContent-Type: application/x-www-form-urlencoded\n\n| Key | Value |\n| --- |\ \ --- |\n| grant_type: | client_credentials |\n| client_id: | (Your client ID)\ \ |\n| client_secret: | (Your client secret) |\n\nFor your security and convenience,\ \ you may pause and unpause your API access on our Integrations page. All requests\ \ will be rejected while your API access is paused, including requests to issue\ \ tokens.\n" version: v1 x-logo: url: https://api.listrak.com/Email/Resources/Images/Logo.png altText: Listrak href: https://www.listrak.com backgroundColor: '#fafafa' servers: - url: https://api.listrak.com/crosschannel/v1 paths: /eventConfigurations/{eventUID}/events: post: tags: - Events summary: Route to post new Custom Events. description: A route to post new Custom Events associated with the given Custom Event Configuration. The data payload for these events should match the schema defined through your Custom Events Integration. operationId: postEvents parameters: - name: eventUID in: path required: true schema: type: string requestBody: content: application/json: schema: $ref: '#/components/schemas/EventList' required: true responses: '404': description: Entity Not Found headers: X-Frame-Options: schema: type: string Strict-Transport-Security: schema: type: string X-Content-Type-Options: schema: type: string Content-Security-Policy: schema: type: string '200': description: Contains the response information for each submitted identifier, as well as metadata associated with the overall response status. content: application/json: schema: $ref: '#/components/schemas/CustomEventPostResponse' '400': description: Bad Request headers: X-Frame-Options: schema: type: string Strict-Transport-Security: schema: type: string X-Content-Type-Options: schema: type: string Content-Security-Policy: schema: type: string '500': description: Internal Server Error headers: X-Frame-Options: schema: type: string Strict-Transport-Security: schema: type: string X-Content-Type-Options: schema: type: string Content-Security-Policy: schema: type: string x-codeSamples: - lang: JSON source: "{\n \"events\": [\n {\n \"identifiers\": [\n\ \ {\n \"identifierValue\": \"alice@listrak.com\"\ ,\n \"identifierType\": \"EmailAddress\"\n \ \ },\n {\n \"identifierValue\": \"\ 5551234567\",\n \"identifierType\": \"PhoneNumber\"\n\ \ }\n ],\n \"dataFields\": {\n \ \ \"firstName\": \"Alice\",\n \"lastName\": \"\ Smith\"\n }\n },\n {\n \"identifiers\"\ : [\n {\n \"identifierValue\": \"bob@listrak.com\"\ ,\n \"identifierType\": \"EmailAddress\"\n \ \ },\n {\n \"identifierValue\": \"\ 5551234568\",\n \"identifierType\": \"PhoneNumber\"\n\ \ }\n ],\n \"dataFields\": {\n \ \ \"firstName\": \"Bob\",\n \"lastName\": \"Smith\"\ \n }\n }\n ]\n}" /eventConfigurations: get: tags: - EventConfigurations summary: Get all event configurations. description: Get a list of all event configurations with names and unique identifiers. These can be used to determine which event configuration should be used to post your custom events. operationId: getEventConfigurations responses: '400': description: Bad Request headers: X-Frame-Options: schema: type: string Strict-Transport-Security: schema: type: string X-Content-Type-Options: schema: type: string Content-Security-Policy: schema: type: string '500': description: Internal Server Error headers: X-Frame-Options: schema: type: string Strict-Transport-Security: schema: type: string X-Content-Type-Options: schema: type: string Content-Security-Policy: schema: type: string '200': description: Returns Custom Event List as a JSON document, along with the metadata content: application/json: schema: $ref: '#/components/schemas/CustomEventConfigurationListResponse' /eventConfigurations/{eventUID}: get: tags: - EventConfigurations summary: Get a Custom Event Configuration. description: Get the details for a specific Custom Event Configuration. operationId: getSchemaByEventUid parameters: - name: eventUID in: path required: true schema: type: string responses: '404': description: Entity Not Found headers: X-Frame-Options: schema: type: string Strict-Transport-Security: schema: type: string X-Content-Type-Options: schema: type: string Content-Security-Policy: schema: type: string '200': description: The details for a specific Custom Event Configuration. content: application/json: schema: $ref: '#/components/schemas/CustomEventDetailResponse' '400': description: Bad Request headers: X-Frame-Options: schema: type: string Strict-Transport-Security: schema: type: string X-Content-Type-Options: schema: type: string Content-Security-Policy: schema: type: string '500': description: Internal Server Error headers: X-Frame-Options: schema: type: string Strict-Transport-Security: schema: type: string X-Content-Type-Options: schema: type: string Content-Security-Policy: schema: type: string '403': description: Request Forbidden headers: X-Frame-Options: schema: type: string Strict-Transport-Security: schema: type: string X-Content-Type-Options: schema: type: string Content-Security-Policy: schema: type: string components: schemas: ResponseMetaData: type: object properties: statusCode: type: integer description: Response Status Code format: int32 message: type: string description: Explanation for the code errors: type: array items: $ref: '#/components/schemas/Error' CustomEventConfigurationListResponse: title: CustomEventConfigurationListResponse type: object properties: data: type: array items: $ref: '#/components/schemas/CustomEventConfiguration' meta: $ref: '#/components/schemas/ResponseMetaData' Identifier: type: object properties: identifierValue: type: string description: The value for the identifier. identifierType: enum: - EmailAddress - PhoneNumber - MobileContactUid type: string description: The type of identifier, e.g. an email address. description: The identifier information that can be used to contact the person associated with this event. CustomEventDetailResponse: title: CustomEventDetailResponse type: object properties: data: $ref: '#/components/schemas/CustomEventDetail' meta: $ref: '#/components/schemas/ResponseMetaData' EventList: type: object properties: events: type: array items: $ref: '#/components/schemas/Event' description: The list of events. RecipientDetailResponse: type: object properties: identifiers: type: array items: $ref: '#/components/schemas/Identifier' description: All recipient identifiers that received this included status code statusCode: type: integer description: Response Status Code for the recipients in this JSON object format: int32 errors: type: array items: $ref: '#/components/schemas/RecipientDetailResponseError' description: Errors, if any, that occured to cause a non-200 series status code CustomEventPostResponse: title: CustomEventPostResponse type: object properties: data: type: array items: $ref: '#/components/schemas/RecipientDetailResponse' meta: $ref: '#/components/schemas/ResponseMetaData' Event: type: object properties: identifiers: type: array items: $ref: '#/components/schemas/Identifier' description: A list of identifiers for the person associated with this event. One or more must be included. Please note that consuming services may not be able to act on all identifiers of the same type on an event (e.g. multiple email addresses on a single event) - please consider this when creating events. dataFields: type: object additionalProperties: type: string description: An object containing keys and values for user-defined data. This data should match the fields defined when creating the Custom Event Schema defined through your Cross Channel Integration. While the values may be passed as strings, it should be possible to parse these values into their defined types. Omitted values will not cause errors, but will lead to gaps in the available data for personalization. Additional fields beyond those defined in the schema will be discarded. description: Custom Events Configuration Error: type: object properties: userMessage: type: string internalMessage: type: string description: Internal Message CustomEventConfiguration: type: object properties: eventUID: type: string description: Event UID format: uuid eventName: type: string description: Event Name description: Custom Events Configuration RecipientDetailResponseError: type: object properties: errorType: type: string description: The type of error format: string errorMessage: type: string description: The error message format: string CustomEventDetail: type: object properties: eventUID: type: string description: Event UID format: uuid eventName: type: string description: Event Name eventSchemaAttrs: type: object additionalProperties: enum: - String - Int - Double - Date type: string description: Key value pairs with the key as the name of the schema property and the value as its type (String, Int, Double, Date). featureAccess: type: array items: enum: - Workflow type: string description: Array of values to determine which features have access to this event. description: Custom Events Schema securitySchemes: Authorizer: type: apiKey name: Authorization in: header x-amazon-apigateway-authtype: custom tags: - name: Events description: REST endpoints to manage Custom Events. - name: EventConfigurations description: REST endpoints to manage Custom Event Configurations. x-amazon-apigateway-security-policy: TLS_1_0 x-tagGroups: - name: API Reference tags: - Events - EventConfigurations