> ## Documentation Index
> Fetch the complete documentation index at: https://loops.so/docs/llms.txt
> Use this file to discover all available pages before exploring further.

# Ensure a transactional email has a draft

> Ensure a transactional email has a draft email message ready for editing, creating one from the published version if no draft currently exists.

If a draft email message already exists, it is returned unchanged. Otherwise a
new empty draft is created (seeded from the most recent published version when
present).

Use the returned `draftEmailMessageId` and `draftEmailMessageContentRevisionId` when calling [Update an email message](/api-reference/update-email-message) to edit the draft's content.

## Request

### Path parameters

<ParamField path="id" type="string" required>
  The ID of the transactional email.
</ParamField>

### Body

No request body.

## Response

### Success

<ResponseField name="id" type="string" required>
  The transactional email ID.
</ResponseField>

<ResponseField name="name" type="string" required>
  The transactional email's name.
</ResponseField>

<ResponseField name="draftEmailMessageId" type="nullable string" required>
  The ID of the draft [email message](/api-reference/update-email-message).
</ResponseField>

<ResponseField name="draftEmailMessageContentRevisionId" type="nullable string" required>
  The `contentRevisionId` of the draft email message. Pass this as
  `expectedRevisionId` on your first update via
  [Update an email message](/api-reference/update-email-message).
</ResponseField>

<ResponseField name="publishedEmailMessageId" type="nullable string" required>
  The ID of the published email message, if one exists.
</ResponseField>

<ResponseField name="transactionalGroupId" type="nullable string">
  The ID of the group this transactional email belongs to.
</ResponseField>

<ResponseField name="createdAt" type="string" required>
  ISO 8601 timestamp for when the transactional email was created.
</ResponseField>

<ResponseField name="updatedAt" type="string" required>
  ISO 8601 timestamp for when the transactional email was last updated.
</ResponseField>

<ResponseField name="dataVariables" type="array" required>
  Data variable names used by the published email. Empty for unpublished
  transactional emails.
</ResponseField>

### Error

If `id` is invalid, or if no sending domain is configured, a
`400 Bad Request` is returned.

A `404 Not Found` is returned if the transactional email does not exist.

If the API key is invalid (or content API is not enabled for your team), a
`401 Unauthorized` is returned.

<ResponseField name="message" type="string" required>
  An error message describing what went wrong.
</ResponseField>

<ResponseExample>
  ```json Response theme={"dark"}
  {
    "id": "cmnx1d95z001llilji4vapgqs",
    "name": "Welcome email",
    "draftEmailMessageId": "cmn5zia4i0017tzli8ric8giv",
    "draftEmailMessageContentRevisionId": "rev_01hxyz",
    "publishedEmailMessageId": "cmn5bia4i0217tzli8ric8giv",
    "transactionalGroupId": "tgrp_01hxyz",
    "createdAt": "2026-03-28T15:00:00.000Z",
    "updatedAt": "2026-03-28T15:20:00.000Z",
    "dataVariables": []
  }
  ```

  ```json Error response theme={"dark"}
  {
    "message": "Transactional email not found."
  }
  ```
</ResponseExample>
