The Dyspatch API is based on the REST paradigm, and features resource based URLs with standard HTTP response codes to indicate errors. We use standard HTTP authentication and request verbs, and all responses are JSON formatted. See our Implementation Guide for more details on how to implement Dyspatch.
Templates are the email templates found in your Dyspatch account. Only the published Template Draft is returned.
A typical integration will start with using the Templates list endpoint to iterate through and sync Templates.
Gets a list of Template Metadata objects for all templates. Up to 25 results returned before results are paginated.
cursor | string A cursor value used to retrieve a specific page from a paginated result set. |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
{- "cursor": {
- "next": "string",
- "hasMore": true
}, - "data": [
- {
- "id": "tem_g3L7Cw6Hp5wU",
- "name": "Template Name",
- "description": "Description of Template",
- "url": "/templates/tem_g3L7Cw6Hp5wUaf395LehwK",
- "path": "fdr_01gb8vd6pz/fdr_01gqjmdbq/fdr_01gqjmg1",
- "workspaceId": "fdr_01gb8vd6pz",
- "localizations": [
- {
- "id": "loc_g3L7Cw6Hp5wUaf395LehwK",
- "name": "English (US)",
- "url": "/localizations/loc_g3L7Cw6Hp5wUaf395LehwK",
- "localeGroup": "lgr_alka38ajla301",
- "languages": [
- "fr-FR"
]
}
], - "createdAt": "2019-08-24T14:15:22Z",
- "updatedAt": "2019-08-24T14:15:22Z",
- "publishedDraftId": "tdft_g3L7Cw6Hp5wU"
}
]
}
Gets a template object with the matching ID. Templates without a published draft will result in an error.
templateId required | string A template ID |
targetLanguage required | string Enum: "html" "handlebars" "ampscript" "freemarker" "cheetah" "jinja" "liquid" "mandrillhandlebars" The type of templating language to compile as. |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
{- "id": "tem_g3L7Cw6Hp5wU",
- "name": "Template Name",
- "description": "Description of Template",
- "url": "/templates/tem_g3L7Cw6Hp5wUaf395LehwK",
- "compiled": {
- "sender": "example@example.com",
- "replyTo": "example@example.com",
- "subject": "PGh0bWw+PC9odG1sPgo=",
- "html": "PGh0bWw+PC9odG1sPgo=",
- "ampHtml": "PGh0bWwg4pqhNGVtYWlsPjwvaHRtbD4=",
- "text": "dGV4dCBjb250ZW50"
}, - "path": "fdr_01gb8vd6pz/fdr_01gqjmdbq/fdr_01gqjmg1",
- "workspaceId": "fdr_01gb8vd6pz",
- "createdAt": "2019-08-24T14:15:22Z",
- "updatedAt": "2019-08-24T14:15:22Z",
- "publishedDraftId": "tdft_g3L7Cw6Hp5wU",
- "localizations": [
- {
- "id": "loc_g3L7Cw6Hp5wUaf395LehwK",
- "name": "English (US)",
- "url": "/localizations/loc_g3L7Cw6Hp5wUaf395LehwK",
- "localeGroup": "lgr_alka38ajla301",
- "languages": [
- "fr-FR"
]
}
]
}
Renders a template into HTML using the provided data.
templateId required | string A template ID |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
{- "html": "<html>Hello, world!<html>",
- "ampHtml": "<html ⚡4email>Hello, world!<html>",
- "text": "Hello, world!",
- "subject": "Email Subject Line",
- "sender": "example@example.com",
- "replyTo": "example@example.com"
}
Drafts represent unpublished versions of templates that are still mutable. There could be many in progress drafts for a template.
Returns all drafts for your organization.
cursor | string A cursor value used to retrieve a specific page from a paginated result set. |
status | string Value: "awaitingTranslation" Filter the list of drafts by a particular status |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
{- "cursor": {
- "next": "string",
- "hasMore": true
}, - "data": [
- {
- "id": "tdft_g3L7Cw6Hp5wU",
- "templateId": "tem_g3L7Cw6Hp5wU",
- "name": "Draft Name",
- "url": "/drafts/tdft_g3L7Cw6Hp5wUaf395LehwK/dft_g3L7Cw6Hp5wU",
- "path": "fdr_01gb8vd6pz/fdr_01gqjmdbq/fdr_01gqjmg1",
- "workspaceId": "fdr_01gb8vd6pz",
- "createdAt": "2019-08-24T14:15:22Z",
- "updatedAt": "2019-08-24T14:15:22Z",
- "status": "LOCKED_FOR_TRANSLATION",
- "templateName": "Template Name"
}
]
}
Moves the draft into submitted state.
draftId required | string A draft ID |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
Gets a draft object with the matching ID. The "compiled" field will contain the template in the default, unlocalized form.
draftId required | string A draft ID |
targetLanguage required | string Enum: "html" "handlebars" "ampscript" "freemarker" "cheetah" "jinja" "liquid" "mandrillhandlebars" The type of templating language to compile as. |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
{- "id": "tdft_g3L7Cw6Hp5wU",
- "template": "tem_g3L7Cw6Hp5wU",
- "name": "Draft Name",
- "url": "/drafts/tdft_g3L7Cw6Hp5wUaf395LehwK/dft_g3L7Cw6Hp5wU",
- "path": "fdr_01gb8vd6pz/fdr_01gqjmdbq/fdr_01gqjmg1",
- "workspaceId": "fdr_01gb8vd6pz",
- "compiled": {
- "sender": "example@example.com",
- "replyTo": "example@example.com",
- "subject": "PGh0bWw+PC9odG1sPgo=",
- "html": "PGh0bWw+PC9odG1sPgo=",
- "ampHtml": "PGh0bWwg4pqhNGVtYWlsPjwvaHRtbD4=",
- "text": "dGV4dCBjb250ZW50"
}, - "createdAt": "2019-08-24T14:15:22Z",
- "updatedAt": "2019-08-24T14:15:22Z",
- "localizations": [
- {
- "id": "loc_g3L7Cw6Hp5wUaf395LehwK",
- "name": "English (US)",
- "url": "/localizations/loc_g3L7Cw6Hp5wUaf395LehwK",
- "localeGroup": "lgr_alka38ajla301",
- "languages": [
- "fr-FR"
]
}
], - "status": "LOCKED_FOR_TRANSLATION",
- "templateName": "Template Name"
}
Returns localization metadata for the draft
draftId required | string A draft ID |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
[- {
- "id": "loc_g3L7Cw6Hp5wUaf395LehwK",
- "name": "English (US)",
- "url": "/localizations/loc_g3L7Cw6Hp5wUaf395LehwK",
- "localeGroup": "lgr_alka38ajla301",
- "languages": [
- "fr-FR"
]
}
]
Inserts a localization or sets the name on an existing localization that already uses the languageId
draftId required | string A draft ID |
languageId required | string A language ID (eg: en-US) |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
name | string |
{- "name": "English (US)"
}
Deletes the localization with the given language ID if it exists
draftId required | string A draft ID |
languageId required | string A language ID (eg: en-US) |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
Completely replaces any existing translations for the given language with those provided in request body. Variables embedded in keys or values are expected to be in the format %(my_variable)s
and will automatically convert to the correct Dyspatch format depending on the type of template. Accepts key/value pairs in JSON format or in gettext PO file format. For JSON set Content-Type
header to application/json
. For gettext PO format set Content-Type
header to text/x-gettext-translation
.
draftId required | string A draft ID |
languageId required | string A language ID (eg: en-US) |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
property name* additional property | string |
{- "Hello %(name)s": "Bonjour %(name)s",
- "Welcome": "Bienvenue"
}
Returns the list of values that need to be translated for the draft. Set the Accept
header to application/vnd.dyspatch.2023.03+json
to get a JSON object, or text/vnd.dyspatch.2023.03+x-gettext-translation
to get the POT file.
draftId required | string A draft ID |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
[- {
- "key": "string",
- "comment": "string"
}
]
Localization objects are the same as Template objects except they contain localized content.
If your account is using localizations then use this instead of the compiled Template object.
Returns the published content associated with the localization of the matching ID
localizationId required | string A localization ID |
targetLanguage required | string Enum: "html" "handlebars" "ampscript" "freemarker" "cheetah" "jinja" "liquid" "mandrillhandlebars" The type of templating language to compile as. |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
{- "id": "loc_g3L7Cw6Hp5wUaf395LehwK",
- "languages": [
- "fr-FR"
], - "url": "/localizations/loc_g3L7Cw6Hp5wUaf395LehwK",
- "template": "tem_g3L7Cw6Hp5wU",
- "compiled": {
- "sender": "example@example.com",
- "replyTo": "example@example.com",
- "subject": "PGh0bWw+PC9odG1sPgo=",
- "html": "PGh0bWw+PC9odG1sPgo=",
- "ampHtml": "PGh0bWwg4pqhNGVtYWlsPjwvaHRtbD4=",
- "text": "dGV4dCBjb250ZW50"
}, - "createdAt": "2019-08-24T14:15:22Z",
- "updatedAt": "2019-08-24T14:15:22Z",
- "name": "English (US)",
- "localeGroup": "lgr_alka38ajla301"
}
Returns a specific localization object of the matching draft with a matching localization ID
draftId required | string A draft ID |
localizationId required | string A localization ID |
targetLanguage required | string Enum: "html" "handlebars" "ampscript" "freemarker" "cheetah" "jinja" "liquid" "mandrillhandlebars" The type of templating language to compile as. |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
{- "id": "loc_g3L7Cw6Hp5wUaf395LehwK",
- "languages": [
- "fr-FR"
], - "url": "/localizations/loc_g3L7Cw6Hp5wUaf395LehwK",
- "template": "tem_g3L7Cw6Hp5wU",
- "compiled": {
- "sender": "example@example.com",
- "replyTo": "example@example.com",
- "subject": "PGh0bWw+PC9odG1sPgo=",
- "html": "PGh0bWw+PC9odG1sPgo=",
- "ampHtml": "PGh0bWwg4pqhNGVtYWlsPjwvaHRtbD4=",
- "text": "dGV4dCBjb250ZW50"
}, - "createdAt": "2019-08-24T14:15:22Z",
- "updatedAt": "2019-08-24T14:15:22Z",
- "name": "English (US)",
- "localeGroup": "lgr_alka38ajla301"
}
Gets a list of Workspace objects for all workspaces. Up to 25 results returned before results are paginated.
cursor | string A cursor value used to retrieve a specific page from a paginated result set. |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
{- "cursor": {
- "next": "string",
- "hasMore": true
}, - "data": [
- {
- "id": "fdr_01g0z4d5aw",
- "name": "Name of Folder",
- "description": "Description of Folder",
- "url": "/workspaces/fdr_g3L7Cw6Hp5wUaf395LehwK",
- "createdAt": "2019-08-24T14:15:22Z",
- "updatedAt": "2019-08-24T14:15:22Z"
}
]
}
Gets a Folder with a list of its sub-folders for the provided id.
folderId required | string A workspace/folder ID |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
{- "id": "fdr_01g0z4d5aw",
- "name": "Name of Folder",
- "description": "Description of Folder",
- "url": "/workspaces/fdr_g3L7Cw6Hp5wUaf395LehwK",
- "createdAt": "2019-08-24T14:15:22Z",
- "updatedAt": "2019-08-24T14:15:22Z",
- "subfolders": [
- {
- "id": "fdr_01g0z4d5aw",
- "name": "Name of Folder",
- "description": "Description of Folder",
- "url": "/workspaces/fdr_g3L7Cw6Hp5wUaf395LehwK",
- "createdAt": "2019-08-24T14:15:22Z",
- "updatedAt": "2019-08-24T14:15:22Z"
}
]
}
Gets a list of Blocks
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
{- "cursor": {
- "next": "string",
- "hasMore": true
}, - "data": [
- {
- "id": "blk_01gpe172x7p6aa1c9grr48efq8",
- "name": "Header Block",
- "description": "string",
- "createdAt": "2019-08-24T14:15:22Z",
- "updatedAt": "2019-08-24T14:15:22Z",
- "url": "/blocks/blk_01gpe172x7p6aa1c9grr48efq8"
}
]
}
Gets a block with the matching ID.
blockId required | string A block ID |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
{- "id": "blk_01gpe172x7p6aa1c9grr48efq8",
- "name": "Header Block",
- "description": "string",
- "createdAt": "2019-08-24T14:15:22Z",
- "updatedAt": "2019-08-24T14:15:22Z",
- "url": "/blocks/blk_01gpe172x7p6aa1c9grr48efq8"
}
Returns localization metadata for the block
blockId required | string A block ID |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
[- {
- "id": "loc_g3L7Cw6Hp5wUaf395LehwK",
- "name": "English (US)",
- "url": "/localizations/loc_g3L7Cw6Hp5wUaf395LehwK",
- "localeGroup": "lgr_alka38ajla301",
- "languages": [
- "fr-FR"
]
}
]
Returns the list of values that need to be translated for the block.
blockId required | string A block ID |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
[- {
- "key": "string",
- "comment": "string"
}
]
Inserts a localization or sets the name on an existing localization that already uses the languageId
blockId required | string A block ID |
languageId required | string A language ID (eg: en-US) |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
name | string |
{- "name": "English (US)"
}
Deletes the localization with the given language ID if it exists
blockId required | string A block ID |
languageId required | string A language ID (eg: en-US) |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
Completely replaces any existing translations for the given language with those provided in request body. Variables embedded in keys or values are expected to be in the format %(my_variable)s
and will automatically convert to the correct Dyspatch format depending on the type of template. Accepts key/value pairs in JSON format.
blockId required | string A block ID |
languageId required | string A language ID (eg: en-US) |
Accept required | string A version of the API that should be used for the request. For example, to use version "2023.03", set the value to "application/vnd.dyspatch.2023.03+json" |
property name* additional property | string |
{- "Hello %(name)s": "Bonjour %(name)s",
- "Welcome": "Bienvenue"
}