Sync a workflow

Synchronizes a workflow to the target environment

PUT
/v2/workflows/{workflowId}/sync

Authorization

Authorization<token>

API key authentication. Allowed headers-- "Authorization: ApiKey <api_key>".

In: header

Request Body

application/jsonRequired

Sync workflow details

targetEnvironmentIdRequiredstring

Target environment identifier to sync the workflow to

Path Parameters

workflowIdRequiredstring

Header Parameters

idempotency-keystring

A header for idempotency purposes

Response Body

OK

nameRequiredstring

Name of the workflow

descriptionstring

Description of the workflow

tagsarray<string>

Tags associated with the workflow

activeboolean

Whether the workflow is active

Default: false
validatePayloadboolean

Enable or disable payload schema validation

payloadSchemaobject | null

The payload JSON Schema for the workflow

isTranslationEnabledboolean

Enable or disable translations for this workflow

Default: false
_idRequiredstring

Database identifier of the workflow

workflowIdRequiredstring

Workflow identifier

slugRequiredstring

Slug of the workflow

updatedAtRequiredstring

Last updated timestamp

createdAtRequiredstring

Creation timestamp

updatedByobject

User who last updated the workflow

lastPublishedAtstring | null

Timestamp of the last workflow publication

lastPublishedByobject

User who last published the workflow

stepsRequiredarray<object | object | object | object | object | object | object | object | object>

Steps of the workflow

originRequiredstring

Origin of the layout

Value in: "novu-cloud" | "novu-cloud-v1" | "external"
preferencesRequiredobject

Preferences for the workflow

statusRequiredstring

Status of the workflow

Value in: "ACTIVE" | "INACTIVE" | "ERROR"
issuesobject

Runtime issues for workflow creation and update

lastTriggeredAtstring | null

Timestamp of the last workflow trigger

payloadExampleobject | null

Generated payload example based on the payload schema

severityRequiredstring

Severity of the workflow

Value in: "high" | "medium" | "low" | "none"
export interface Response {
  /**
   * Name of the workflow
   */
  name: string;
  /**
   * Description of the workflow
   */
  description?: string;
  /**
   * Tags associated with the workflow
   */
  tags?: string[];
  /**
   * Whether the workflow is active
   */
  active?: boolean;
  /**
   * Enable or disable payload schema validation
   */
  validatePayload?: boolean;
  /**
   * The payload JSON Schema for the workflow
   */
  payloadSchema?: {
    [k: string]: unknown;
  } | null;
  /**
   * Enable or disable translations for this workflow
   */
  isTranslationEnabled?: boolean;
  /**
   * Database identifier of the workflow
   */
  _id: string;
  /**
   * Workflow identifier
   */
  workflowId: string;
  /**
   * Slug of the workflow
   */
  slug: string;
  /**
   * Last updated timestamp
   */
  updatedAt: string;
  /**
   * Creation timestamp
   */
  createdAt: string;
  /**
   * User who last updated the workflow
   */
  updatedBy?: UserResponseDto;
  /**
   * Timestamp of the last workflow publication
   */
  lastPublishedAt?: string | null;
  /**
   * User who last published the workflow
   */
  lastPublishedBy?: UserResponseDto1;
  /**
   * Steps of the workflow
   */
  steps: (
    | InAppStepResponseDto
    | EmailStepResponseDto
    | SmsStepResponseDto
    | PushStepResponseDto
    | ChatStepResponseDto
    | DelayStepResponseDto
    | DigestStepResponseDto
    | CustomStepResponseDto
    | ThrottleStepResponseDto
  )[];
  /**
   * Origin of the layout
   */
  origin: "novu-cloud" | "novu-cloud-v1" | "external";
  /**
   * Preferences for the workflow
   */
  preferences: WorkflowPreferencesResponseDto;
  /**
   * Status of the workflow
   */
  status: "ACTIVE" | "INACTIVE" | "ERROR";
  /**
   * Runtime issues for workflow creation and update
   */
  issues?: {
    [k: string]: RuntimeIssueDto;
  };
  /**
   * Timestamp of the last workflow trigger
   */
  lastTriggeredAt?: string | null;
  /**
   * Generated payload example based on the payload schema
   */
  payloadExample?: {
    [k: string]: unknown;
  } | null;
  /**
   * Severity of the workflow
   */
  severity: "high" | "medium" | "low" | "none";
}
export interface UserResponseDto {
  /**
   * User ID
   */
  _id: string;
  /**
   * User first name
   */
  firstName?: string | null;
  /**
   * User last name
   */
  lastName?: string | null;
  /**
   * User external ID
   */
  externalId?: string | null;
}
export interface UserResponseDto1 {
  /**
   * User ID
   */
  _id: string;
  /**
   * User first name
   */
  firstName?: string | null;
  /**
   * User last name
   */
  lastName?: string | null;
  /**
   * User external ID
   */
  externalId?: string | null;
}
export interface InAppStepResponseDto {
  /**
   * Controls metadata for the in-app step
   */
  controls: InAppControlsMetadataResponseDto;
  /**
   * Control values for the in-app step
   */
  controlValues?: InAppControlDto1;
  /**
   * JSON Schema for variables, follows the JSON Schema standard
   */
  variables: {
    [k: string]: unknown;
  };
  /**
   * Unique identifier of the step
   */
  stepId: string;
  /**
   * Database identifier of the step
   */
  _id: string;
  /**
   * Name of the step
   */
  name: string;
  /**
   * Slug of the step
   */
  slug: string;
  /**
   * Type of the step
   */
  type: "in_app" | "email" | "sms" | "chat" | "push" | "digest" | "trigger" | "delay" | "throttle" | "custom";
  /**
   * Origin of the layout
   */
  origin: "novu-cloud" | "novu-cloud-v1" | "external";
  /**
   * Workflow identifier
   */
  workflowId: string;
  /**
   * Workflow database identifier
   */
  workflowDatabaseId: string;
  /**
   * Issues associated with the step
   */
  issues?: StepIssuesDto;
}
export interface InAppControlsMetadataResponseDto {
  /**
   * JSON Schema for data
   */
  dataSchema?: {
    [k: string]: unknown;
  };
  /**
   * UI Schema for rendering
   */
  uiSchema?: UiSchema;
  /**
   * Control values specific to In-App
   */
  values: InAppControlDto;
}
export interface UiSchema {
  /**
   * Group of the UI Schema
   */
  group?: "IN_APP" | "EMAIL" | "DIGEST" | "DELAY" | "THROTTLE" | "SMS" | "CHAT" | "PUSH" | "SKIP" | "LAYOUT";
  /**
   * Properties of the UI Schema
   */
  properties?: {
    [k: string]: UiSchemaProperty;
  };
}
export interface UiSchemaProperty {
  /**
   * Placeholder for the UI Schema Property
   */
  placeholder?:
    | string
    | number
    | boolean
    | {
        [k: string]: unknown;
      }
    | (
        | string
        | number
        | boolean
        | {
            [k: string]: unknown;
          }
      )[];
  /**
   * Component type for the UI Schema Property
   */
  component:
    | "EMAIL_EDITOR_SELECT"
    | "LAYOUT_SELECT"
    | "BLOCK_EDITOR"
    | "EMAIL_BODY"
    | "TEXT_FULL_LINE"
    | "TEXT_INLINE_LABEL"
    | "IN_APP_BODY"
    | "IN_APP_AVATAR"
    | "IN_APP_PRIMARY_SUBJECT"
    | "IN_APP_BUTTON_DROPDOWN"
    | "IN_APP_DISABLE_SANITIZATION_SWITCH"
    | "DISABLE_SANITIZATION_SWITCH"
    | "URL_TEXT_BOX"
    | "DIGEST_AMOUNT"
    | "DIGEST_UNIT"
    | "DIGEST_TYPE"
    | "DIGEST_KEY"
    | "DIGEST_CRON"
    | "DELAY_AMOUNT"
    | "DELAY_UNIT"
    | "DELAY_TYPE"
    | "DELAY_CRON"
    | "THROTTLE_TYPE"
    | "THROTTLE_WINDOW"
    | "THROTTLE_UNIT"
    | "THROTTLE_DYNAMIC_KEY"
    | "THROTTLE_THRESHOLD"
    | "THROTTLE_KEY"
    | "EXTEND_TO_SCHEDULE"
    | "SMS_BODY"
    | "CHAT_BODY"
    | "PUSH_BODY"
    | "PUSH_SUBJECT"
    | "QUERY_EDITOR"
    | "DATA"
    | "LAYOUT_EMAIL";
  /**
   * Properties of the UI Schema
   */
  properties?: {
    [k: string]: UiSchemaProperty1;
  };
}
export interface UiSchemaProperty1 {
  /**
   * Placeholder for the UI Schema Property
   */
  placeholder?:
    | string
    | number
    | boolean
    | {
        [k: string]: unknown;
      }
    | (
        | string
        | number
        | boolean
        | {
            [k: string]: unknown;
          }
      )[];
  /**
   * Component type for the UI Schema Property
   */
  component:
    | "EMAIL_EDITOR_SELECT"
    | "LAYOUT_SELECT"
    | "BLOCK_EDITOR"
    | "EMAIL_BODY"
    | "TEXT_FULL_LINE"
    | "TEXT_INLINE_LABEL"
    | "IN_APP_BODY"
    | "IN_APP_AVATAR"
    | "IN_APP_PRIMARY_SUBJECT"
    | "IN_APP_BUTTON_DROPDOWN"
    | "IN_APP_DISABLE_SANITIZATION_SWITCH"
    | "DISABLE_SANITIZATION_SWITCH"
    | "URL_TEXT_BOX"
    | "DIGEST_AMOUNT"
    | "DIGEST_UNIT"
    | "DIGEST_TYPE"
    | "DIGEST_KEY"
    | "DIGEST_CRON"
    | "DELAY_AMOUNT"
    | "DELAY_UNIT"
    | "DELAY_TYPE"
    | "DELAY_CRON"
    | "THROTTLE_TYPE"
    | "THROTTLE_WINDOW"
    | "THROTTLE_UNIT"
    | "THROTTLE_DYNAMIC_KEY"
    | "THROTTLE_THRESHOLD"
    | "THROTTLE_KEY"
    | "EXTEND_TO_SCHEDULE"
    | "SMS_BODY"
    | "CHAT_BODY"
    | "PUSH_BODY"
    | "PUSH_SUBJECT"
    | "QUERY_EDITOR"
    | "DATA"
    | "LAYOUT_EMAIL";
  /**
   * Properties of the UI Schema
   */
  properties?: {
    [k: string]: UiSchemaProperty1;
  };
}
export interface InAppControlDto {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Content/body of the in-app message. Required if subject is empty.
   */
  body?: string;
  /**
   * Subject/title of the in-app message. Required if body is empty.
   */
  subject?: string;
  /**
   * URL for an avatar image. Must be a valid URL or start with / or {{ variable }}.
   */
  avatar?: string;
  /**
   * Primary action button details.
   */
  primaryAction?: ActionDto;
  /**
   * Secondary action button details.
   */
  secondaryAction?: ActionDto1;
  /**
   * Redirection URL configuration for the main content click (if no actions defined/clicked)..
   */
  redirect?: RedirectDto1;
  /**
   * Disable sanitization of the output.
   */
  disableOutputSanitization?: boolean;
  /**
   * Additional data payload for the step.
   */
  data?: {
    [k: string]: unknown;
  };
}
export interface ActionDto {
  /**
   * Label for the action button.
   */
  label?: string;
  /**
   * Redirect configuration for the action.
   */
  redirect?: RedirectDto;
}
export interface RedirectDto {
  /**
   * URL for redirection. Must be a valid URL or start with / or {{ variable }}.
   */
  url?: string;
  /**
   * Target window for the redirection.
   */
  target?: "_self" | "_blank" | "_parent" | "_top" | "_unfencedTop";
}
export interface ActionDto1 {
  /**
   * Label for the action button.
   */
  label?: string;
  /**
   * Redirect configuration for the action.
   */
  redirect?: RedirectDto;
}
export interface RedirectDto1 {
  /**
   * URL for redirection. Must be a valid URL or start with / or {{ variable }}.
   */
  url?: string;
  /**
   * Target window for the redirection.
   */
  target?: "_self" | "_blank" | "_parent" | "_top" | "_unfencedTop";
}
export interface InAppControlDto1 {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Content/body of the in-app message. Required if subject is empty.
   */
  body?: string;
  /**
   * Subject/title of the in-app message. Required if body is empty.
   */
  subject?: string;
  /**
   * URL for an avatar image. Must be a valid URL or start with / or {{ variable }}.
   */
  avatar?: string;
  /**
   * Primary action button details.
   */
  primaryAction?: ActionDto;
  /**
   * Secondary action button details.
   */
  secondaryAction?: ActionDto1;
  /**
   * Redirection URL configuration for the main content click (if no actions defined/clicked)..
   */
  redirect?: RedirectDto1;
  /**
   * Disable sanitization of the output.
   */
  disableOutputSanitization?: boolean;
  /**
   * Additional data payload for the step.
   */
  data?: {
    [k: string]: unknown;
  };
}
export interface StepIssuesDto {
  /**
   * Controls-related issues
   */
  controls?: {
    /**
     * @minItems 0
     */
    [k: string]: StepContentIssueDto[];
  };
  /**
   * Integration-related issues
   */
  integration?: {
    /**
     * @minItems 0
     */
    [k: string]: StepIntegrationIssue[];
  };
}
export interface StepContentIssueDto {
  /**
   * Type of step content issue
   */
  issueType:
    | "ILLEGAL_VARIABLE_IN_CONTROL_VALUE"
    | "INVALID_FILTER_ARG_IN_VARIABLE"
    | "MISSING_VALUE"
    | "TIER_LIMIT_EXCEEDED";
  /**
   * Name of the variable related to the issue
   */
  variableName?: string;
  /**
   * Detailed message describing the issue
   */
  message: string;
}
export interface StepIntegrationIssue {
  /**
   * Type of integration issue
   */
  issueType: "MISSING_INTEGRATION" | "INBOX_NOT_CONNECTED";
  /**
   * Name of the variable related to the issue
   */
  variableName?: string;
  /**
   * Detailed message describing the issue
   */
  message: string;
}
export interface EmailStepResponseDto {
  /**
   * Controls metadata for the email step
   */
  controls: EmailControlsMetadataResponseDto;
  /**
   * Control values for the email step
   */
  controlValues?: EmailControlDto1;
  /**
   * JSON Schema for variables, follows the JSON Schema standard
   */
  variables: {
    [k: string]: unknown;
  };
  /**
   * Unique identifier of the step
   */
  stepId: string;
  /**
   * Database identifier of the step
   */
  _id: string;
  /**
   * Name of the step
   */
  name: string;
  /**
   * Slug of the step
   */
  slug: string;
  /**
   * Type of the step
   */
  type: "in_app" | "email" | "sms" | "chat" | "push" | "digest" | "trigger" | "delay" | "throttle" | "custom";
  /**
   * Origin of the layout
   */
  origin: "novu-cloud" | "novu-cloud-v1" | "external";
  /**
   * Workflow identifier
   */
  workflowId: string;
  /**
   * Workflow database identifier
   */
  workflowDatabaseId: string;
  /**
   * Issues associated with the step
   */
  issues?: StepIssuesDto1;
}
export interface EmailControlsMetadataResponseDto {
  /**
   * JSON Schema for data
   */
  dataSchema?: {
    [k: string]: unknown;
  };
  /**
   * UI Schema for rendering
   */
  uiSchema?: UiSchema1;
  /**
   * Control values specific to Email
   */
  values: EmailControlDto;
}
export interface UiSchema1 {
  /**
   * Group of the UI Schema
   */
  group?: "IN_APP" | "EMAIL" | "DIGEST" | "DELAY" | "THROTTLE" | "SMS" | "CHAT" | "PUSH" | "SKIP" | "LAYOUT";
  /**
   * Properties of the UI Schema
   */
  properties?: {
    [k: string]: UiSchemaProperty;
  };
}
export interface EmailControlDto {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Subject of the email.
   */
  subject: string;
  /**
   * Body content of the email, either a valid Maily JSON object, or html string.
   */
  body: string;
  /**
   * Type of editor to use for the body.
   */
  editorType?: "block" | "html";
  /**
   * Disable sanitization of the output.
   */
  disableOutputSanitization?: boolean;
  /**
   * Layout ID to use for the email. Null means no layout, undefined means default layout.
   */
  layoutId?: string | null;
}
export interface EmailControlDto1 {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Subject of the email.
   */
  subject: string;
  /**
   * Body content of the email, either a valid Maily JSON object, or html string.
   */
  body: string;
  /**
   * Type of editor to use for the body.
   */
  editorType?: "block" | "html";
  /**
   * Disable sanitization of the output.
   */
  disableOutputSanitization?: boolean;
  /**
   * Layout ID to use for the email. Null means no layout, undefined means default layout.
   */
  layoutId?: string | null;
}
export interface StepIssuesDto1 {
  /**
   * Controls-related issues
   */
  controls?: {
    /**
     * @minItems 0
     */
    [k: string]: StepContentIssueDto[];
  };
  /**
   * Integration-related issues
   */
  integration?: {
    /**
     * @minItems 0
     */
    [k: string]: StepIntegrationIssue[];
  };
}
export interface SmsStepResponseDto {
  /**
   * Controls metadata for the SMS step
   */
  controls: SmsControlsMetadataResponseDto;
  /**
   * Control values for the SMS step
   */
  controlValues?: SmsControlDto1;
  /**
   * JSON Schema for variables, follows the JSON Schema standard
   */
  variables: {
    [k: string]: unknown;
  };
  /**
   * Unique identifier of the step
   */
  stepId: string;
  /**
   * Database identifier of the step
   */
  _id: string;
  /**
   * Name of the step
   */
  name: string;
  /**
   * Slug of the step
   */
  slug: string;
  /**
   * Type of the step
   */
  type: "in_app" | "email" | "sms" | "chat" | "push" | "digest" | "trigger" | "delay" | "throttle" | "custom";
  /**
   * Origin of the layout
   */
  origin: "novu-cloud" | "novu-cloud-v1" | "external";
  /**
   * Workflow identifier
   */
  workflowId: string;
  /**
   * Workflow database identifier
   */
  workflowDatabaseId: string;
  /**
   * Issues associated with the step
   */
  issues?: StepIssuesDto2;
}
export interface SmsControlsMetadataResponseDto {
  /**
   * JSON Schema for data
   */
  dataSchema?: {
    [k: string]: unknown;
  };
  /**
   * UI Schema for rendering
   */
  uiSchema?: UiSchema2;
  /**
   * Control values specific to SMS
   */
  values: SmsControlDto;
}
export interface UiSchema2 {
  /**
   * Group of the UI Schema
   */
  group?: "IN_APP" | "EMAIL" | "DIGEST" | "DELAY" | "THROTTLE" | "SMS" | "CHAT" | "PUSH" | "SKIP" | "LAYOUT";
  /**
   * Properties of the UI Schema
   */
  properties?: {
    [k: string]: UiSchemaProperty;
  };
}
export interface SmsControlDto {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Content of the SMS message.
   */
  body?: string;
}
export interface SmsControlDto1 {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Content of the SMS message.
   */
  body?: string;
}
export interface StepIssuesDto2 {
  /**
   * Controls-related issues
   */
  controls?: {
    /**
     * @minItems 0
     */
    [k: string]: StepContentIssueDto[];
  };
  /**
   * Integration-related issues
   */
  integration?: {
    /**
     * @minItems 0
     */
    [k: string]: StepIntegrationIssue[];
  };
}
export interface PushStepResponseDto {
  /**
   * Controls metadata for the push step
   */
  controls: PushControlsMetadataResponseDto;
  /**
   * Control values for the push step
   */
  controlValues?: PushControlDto1;
  /**
   * JSON Schema for variables, follows the JSON Schema standard
   */
  variables: {
    [k: string]: unknown;
  };
  /**
   * Unique identifier of the step
   */
  stepId: string;
  /**
   * Database identifier of the step
   */
  _id: string;
  /**
   * Name of the step
   */
  name: string;
  /**
   * Slug of the step
   */
  slug: string;
  /**
   * Type of the step
   */
  type: "in_app" | "email" | "sms" | "chat" | "push" | "digest" | "trigger" | "delay" | "throttle" | "custom";
  /**
   * Origin of the layout
   */
  origin: "novu-cloud" | "novu-cloud-v1" | "external";
  /**
   * Workflow identifier
   */
  workflowId: string;
  /**
   * Workflow database identifier
   */
  workflowDatabaseId: string;
  /**
   * Issues associated with the step
   */
  issues?: StepIssuesDto3;
}
export interface PushControlsMetadataResponseDto {
  /**
   * JSON Schema for data
   */
  dataSchema?: {
    [k: string]: unknown;
  };
  /**
   * UI Schema for rendering
   */
  uiSchema?: UiSchema3;
  /**
   * Control values specific to Push
   */
  values: PushControlDto;
}
export interface UiSchema3 {
  /**
   * Group of the UI Schema
   */
  group?: "IN_APP" | "EMAIL" | "DIGEST" | "DELAY" | "THROTTLE" | "SMS" | "CHAT" | "PUSH" | "SKIP" | "LAYOUT";
  /**
   * Properties of the UI Schema
   */
  properties?: {
    [k: string]: UiSchemaProperty;
  };
}
export interface PushControlDto {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Subject/title of the push notification.
   */
  subject?: string;
  /**
   * Body content of the push notification.
   */
  body?: string;
}
export interface PushControlDto1 {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Subject/title of the push notification.
   */
  subject?: string;
  /**
   * Body content of the push notification.
   */
  body?: string;
}
export interface StepIssuesDto3 {
  /**
   * Controls-related issues
   */
  controls?: {
    /**
     * @minItems 0
     */
    [k: string]: StepContentIssueDto[];
  };
  /**
   * Integration-related issues
   */
  integration?: {
    /**
     * @minItems 0
     */
    [k: string]: StepIntegrationIssue[];
  };
}
export interface ChatStepResponseDto {
  /**
   * Controls metadata for the chat step
   */
  controls: ChatControlsMetadataResponseDto;
  /**
   * Control values for the chat step
   */
  controlValues?: ChatControlDto1;
  /**
   * JSON Schema for variables, follows the JSON Schema standard
   */
  variables: {
    [k: string]: unknown;
  };
  /**
   * Unique identifier of the step
   */
  stepId: string;
  /**
   * Database identifier of the step
   */
  _id: string;
  /**
   * Name of the step
   */
  name: string;
  /**
   * Slug of the step
   */
  slug: string;
  /**
   * Type of the step
   */
  type: "in_app" | "email" | "sms" | "chat" | "push" | "digest" | "trigger" | "delay" | "throttle" | "custom";
  /**
   * Origin of the layout
   */
  origin: "novu-cloud" | "novu-cloud-v1" | "external";
  /**
   * Workflow identifier
   */
  workflowId: string;
  /**
   * Workflow database identifier
   */
  workflowDatabaseId: string;
  /**
   * Issues associated with the step
   */
  issues?: StepIssuesDto4;
}
export interface ChatControlsMetadataResponseDto {
  /**
   * JSON Schema for data
   */
  dataSchema?: {
    [k: string]: unknown;
  };
  /**
   * UI Schema for rendering
   */
  uiSchema?: UiSchema4;
  /**
   * Control values specific to Chat
   */
  values: ChatControlDto;
}
export interface UiSchema4 {
  /**
   * Group of the UI Schema
   */
  group?: "IN_APP" | "EMAIL" | "DIGEST" | "DELAY" | "THROTTLE" | "SMS" | "CHAT" | "PUSH" | "SKIP" | "LAYOUT";
  /**
   * Properties of the UI Schema
   */
  properties?: {
    [k: string]: UiSchemaProperty;
  };
}
export interface ChatControlDto {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Content of the chat message.
   */
  body?: string;
}
export interface ChatControlDto1 {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Content of the chat message.
   */
  body?: string;
}
export interface StepIssuesDto4 {
  /**
   * Controls-related issues
   */
  controls?: {
    /**
     * @minItems 0
     */
    [k: string]: StepContentIssueDto[];
  };
  /**
   * Integration-related issues
   */
  integration?: {
    /**
     * @minItems 0
     */
    [k: string]: StepIntegrationIssue[];
  };
}
export interface DelayStepResponseDto {
  /**
   * Controls metadata for the delay step
   */
  controls: DelayControlsMetadataResponseDto;
  /**
   * Control values for the delay step
   */
  controlValues?: DelayControlDto1;
  /**
   * JSON Schema for variables, follows the JSON Schema standard
   */
  variables: {
    [k: string]: unknown;
  };
  /**
   * Unique identifier of the step
   */
  stepId: string;
  /**
   * Database identifier of the step
   */
  _id: string;
  /**
   * Name of the step
   */
  name: string;
  /**
   * Slug of the step
   */
  slug: string;
  /**
   * Type of the step
   */
  type: "in_app" | "email" | "sms" | "chat" | "push" | "digest" | "trigger" | "delay" | "throttle" | "custom";
  /**
   * Origin of the layout
   */
  origin: "novu-cloud" | "novu-cloud-v1" | "external";
  /**
   * Workflow identifier
   */
  workflowId: string;
  /**
   * Workflow database identifier
   */
  workflowDatabaseId: string;
  /**
   * Issues associated with the step
   */
  issues?: StepIssuesDto5;
}
export interface DelayControlsMetadataResponseDto {
  /**
   * JSON Schema for data
   */
  dataSchema?: {
    [k: string]: unknown;
  };
  /**
   * UI Schema for rendering
   */
  uiSchema?: UiSchema5;
  /**
   * Control values specific to Delay
   */
  values: DelayControlDto;
}
export interface UiSchema5 {
  /**
   * Group of the UI Schema
   */
  group?: "IN_APP" | "EMAIL" | "DIGEST" | "DELAY" | "THROTTLE" | "SMS" | "CHAT" | "PUSH" | "SKIP" | "LAYOUT";
  /**
   * Properties of the UI Schema
   */
  properties?: {
    [k: string]: UiSchemaProperty;
  };
}
export interface DelayControlDto {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Type of the delay. Currently only 'regular' is supported by the schema.
   */
  type?: "regular" | "timed";
  /**
   * Amount of time to delay.
   */
  amount?: number;
  /**
   * Unit of time for the delay amount.
   */
  unit?: "seconds" | "minutes" | "hours" | "days" | "weeks" | "months";
  /**
   * Cron expression for the delay. Min length 1.
   */
  cron?: string;
}
export interface DelayControlDto1 {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * Type of the delay. Currently only 'regular' is supported by the schema.
   */
  type?: "regular" | "timed";
  /**
   * Amount of time to delay.
   */
  amount?: number;
  /**
   * Unit of time for the delay amount.
   */
  unit?: "seconds" | "minutes" | "hours" | "days" | "weeks" | "months";
  /**
   * Cron expression for the delay. Min length 1.
   */
  cron?: string;
}
export interface StepIssuesDto5 {
  /**
   * Controls-related issues
   */
  controls?: {
    /**
     * @minItems 0
     */
    [k: string]: StepContentIssueDto[];
  };
  /**
   * Integration-related issues
   */
  integration?: {
    /**
     * @minItems 0
     */
    [k: string]: StepIntegrationIssue[];
  };
}
export interface DigestStepResponseDto {
  /**
   * Controls metadata for the digest step
   */
  controls: DigestControlsMetadataResponseDto;
  /**
   * Control values for the digest step
   */
  controlValues?: DigestControlDto1;
  /**
   * JSON Schema for variables, follows the JSON Schema standard
   */
  variables: {
    [k: string]: unknown;
  };
  /**
   * Unique identifier of the step
   */
  stepId: string;
  /**
   * Database identifier of the step
   */
  _id: string;
  /**
   * Name of the step
   */
  name: string;
  /**
   * Slug of the step
   */
  slug: string;
  /**
   * Type of the step
   */
  type: "in_app" | "email" | "sms" | "chat" | "push" | "digest" | "trigger" | "delay" | "throttle" | "custom";
  /**
   * Origin of the layout
   */
  origin: "novu-cloud" | "novu-cloud-v1" | "external";
  /**
   * Workflow identifier
   */
  workflowId: string;
  /**
   * Workflow database identifier
   */
  workflowDatabaseId: string;
  /**
   * Issues associated with the step
   */
  issues?: StepIssuesDto6;
}
export interface DigestControlsMetadataResponseDto {
  /**
   * JSON Schema for data
   */
  dataSchema?: {
    [k: string]: unknown;
  };
  /**
   * UI Schema for rendering
   */
  uiSchema?: UiSchema6;
  /**
   * Control values specific to Digest
   */
  values: DigestControlDto;
}
export interface UiSchema6 {
  /**
   * Group of the UI Schema
   */
  group?: "IN_APP" | "EMAIL" | "DIGEST" | "DELAY" | "THROTTLE" | "SMS" | "CHAT" | "PUSH" | "SKIP" | "LAYOUT";
  /**
   * Properties of the UI Schema
   */
  properties?: {
    [k: string]: UiSchemaProperty;
  };
}
export interface DigestControlDto {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * The type of digest strategy. Determines which fields are applicable.
   */
  type?: "regular" | "timed";
  /**
   * The amount of time for the digest interval (for REGULAR type). Min 1.
   */
  amount?: number;
  /**
   * The unit of time for the digest interval (for REGULAR type).
   */
  unit?: "seconds" | "minutes" | "hours" | "days" | "weeks" | "months";
  /**
   * Configuration for look-back window (for REGULAR type).
   */
  lookBackWindow?: LookBackWindowDto;
  /**
   * Cron expression for TIMED digest. Min length 1.
   */
  cron?: string;
  /**
   * Specify a custom key for digesting events instead of the default event key.
   */
  digestKey?: string;
}
export interface LookBackWindowDto {
  /**
   * Amount of time for the look-back window.
   */
  amount: number;
  /**
   * Unit of time for the look-back window.
   */
  unit: "seconds" | "minutes" | "hours" | "days" | "weeks" | "months";
}
export interface DigestControlDto1 {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * The type of digest strategy. Determines which fields are applicable.
   */
  type?: "regular" | "timed";
  /**
   * The amount of time for the digest interval (for REGULAR type). Min 1.
   */
  amount?: number;
  /**
   * The unit of time for the digest interval (for REGULAR type).
   */
  unit?: "seconds" | "minutes" | "hours" | "days" | "weeks" | "months";
  /**
   * Configuration for look-back window (for REGULAR type).
   */
  lookBackWindow?: LookBackWindowDto;
  /**
   * Cron expression for TIMED digest. Min length 1.
   */
  cron?: string;
  /**
   * Specify a custom key for digesting events instead of the default event key.
   */
  digestKey?: string;
}
export interface StepIssuesDto6 {
  /**
   * Controls-related issues
   */
  controls?: {
    /**
     * @minItems 0
     */
    [k: string]: StepContentIssueDto[];
  };
  /**
   * Integration-related issues
   */
  integration?: {
    /**
     * @minItems 0
     */
    [k: string]: StepIntegrationIssue[];
  };
}
export interface CustomStepResponseDto {
  /**
   * Controls metadata for the custom step
   */
  controls: CustomControlsMetadataResponseDto;
  /**
   * Control values for the custom step
   */
  controlValues?: CustomControlDto1;
  /**
   * JSON Schema for variables, follows the JSON Schema standard
   */
  variables: {
    [k: string]: unknown;
  };
  /**
   * Unique identifier of the step
   */
  stepId: string;
  /**
   * Database identifier of the step
   */
  _id: string;
  /**
   * Name of the step
   */
  name: string;
  /**
   * Slug of the step
   */
  slug: string;
  /**
   * Type of the step
   */
  type: "in_app" | "email" | "sms" | "chat" | "push" | "digest" | "trigger" | "delay" | "throttle" | "custom";
  /**
   * Origin of the layout
   */
  origin: "novu-cloud" | "novu-cloud-v1" | "external";
  /**
   * Workflow identifier
   */
  workflowId: string;
  /**
   * Workflow database identifier
   */
  workflowDatabaseId: string;
  /**
   * Issues associated with the step
   */
  issues?: StepIssuesDto7;
}
export interface CustomControlsMetadataResponseDto {
  /**
   * JSON Schema for data
   */
  dataSchema?: {
    [k: string]: unknown;
  };
  /**
   * UI Schema for rendering
   */
  uiSchema?: UiSchema7;
  /**
   * Control values specific to Custom step
   */
  values: CustomControlDto;
}
export interface UiSchema7 {
  /**
   * Group of the UI Schema
   */
  group?: "IN_APP" | "EMAIL" | "DIGEST" | "DELAY" | "THROTTLE" | "SMS" | "CHAT" | "PUSH" | "SKIP" | "LAYOUT";
  /**
   * Properties of the UI Schema
   */
  properties?: {
    [k: string]: UiSchemaProperty;
  };
}
export interface CustomControlDto {
  /**
   * Custom control values for the step.
   */
  custom?: {
    [k: string]: unknown;
  };
}
export interface CustomControlDto1 {
  /**
   * Custom control values for the step.
   */
  custom?: {
    [k: string]: unknown;
  };
}
export interface StepIssuesDto7 {
  /**
   * Controls-related issues
   */
  controls?: {
    /**
     * @minItems 0
     */
    [k: string]: StepContentIssueDto[];
  };
  /**
   * Integration-related issues
   */
  integration?: {
    /**
     * @minItems 0
     */
    [k: string]: StepIntegrationIssue[];
  };
}
export interface ThrottleStepResponseDto {
  /**
   * Controls metadata for the throttle step
   */
  controls: ThrottleControlsMetadataResponseDto;
  /**
   * Control values for the throttle step
   */
  controlValues?: ThrottleControlDto1;
  /**
   * JSON Schema for variables, follows the JSON Schema standard
   */
  variables: {
    [k: string]: unknown;
  };
  /**
   * Unique identifier of the step
   */
  stepId: string;
  /**
   * Database identifier of the step
   */
  _id: string;
  /**
   * Name of the step
   */
  name: string;
  /**
   * Slug of the step
   */
  slug: string;
  /**
   * Type of the step
   */
  type: "in_app" | "email" | "sms" | "chat" | "push" | "digest" | "trigger" | "delay" | "throttle" | "custom";
  /**
   * Origin of the layout
   */
  origin: "novu-cloud" | "novu-cloud-v1" | "external";
  /**
   * Workflow identifier
   */
  workflowId: string;
  /**
   * Workflow database identifier
   */
  workflowDatabaseId: string;
  /**
   * Issues associated with the step
   */
  issues?: StepIssuesDto8;
}
export interface ThrottleControlsMetadataResponseDto {
  /**
   * JSON Schema for data
   */
  dataSchema?: {
    [k: string]: unknown;
  };
  /**
   * UI Schema for rendering
   */
  uiSchema?: UiSchema8;
  /**
   * Control values specific to Throttle
   */
  values: ThrottleControlDto;
}
export interface UiSchema8 {
  /**
   * Group of the UI Schema
   */
  group?: "IN_APP" | "EMAIL" | "DIGEST" | "DELAY" | "THROTTLE" | "SMS" | "CHAT" | "PUSH" | "SKIP" | "LAYOUT";
  /**
   * Properties of the UI Schema
   */
  properties?: {
    [k: string]: UiSchemaProperty;
  };
}
export interface ThrottleControlDto {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * The type of throttle window.
   */
  type?: "fixed" | "dynamic";
  /**
   * The amount of time for the throttle window (required for fixed type).
   */
  amount?: number;
  /**
   * The unit of time for the throttle window (required for fixed type).
   */
  unit?: "minutes" | "hours" | "days";
  /**
   * Key path to retrieve dynamic window value (required for dynamic type).
   */
  dynamicKey?: string;
  /**
   * The maximum number of executions allowed within the window. Defaults to 1.
   */
  threshold?: number;
  /**
   * Optional key for grouping throttle rules. If not provided, defaults to workflow and subscriber combination.
   */
  throttleKey?: string;
}
export interface ThrottleControlDto1 {
  /**
   * JSONLogic filter conditions for conditionally skipping the step execution. Supports complex logical operations with AND, OR, and comparison operators. See https://jsonlogic.com/ for full typing reference.
   */
  skip?: {
    [k: string]: unknown;
  };
  /**
   * The type of throttle window.
   */
  type?: "fixed" | "dynamic";
  /**
   * The amount of time for the throttle window (required for fixed type).
   */
  amount?: number;
  /**
   * The unit of time for the throttle window (required for fixed type).
   */
  unit?: "minutes" | "hours" | "days";
  /**
   * Key path to retrieve dynamic window value (required for dynamic type).
   */
  dynamicKey?: string;
  /**
   * The maximum number of executions allowed within the window. Defaults to 1.
   */
  threshold?: number;
  /**
   * Optional key for grouping throttle rules. If not provided, defaults to workflow and subscriber combination.
   */
  throttleKey?: string;
}
export interface StepIssuesDto8 {
  /**
   * Controls-related issues
   */
  controls?: {
    /**
     * @minItems 0
     */
    [k: string]: StepContentIssueDto[];
  };
  /**
   * Integration-related issues
   */
  integration?: {
    /**
     * @minItems 0
     */
    [k: string]: StepIntegrationIssue[];
  };
}
export interface WorkflowPreferencesResponseDto {
  /**
   * User-specific workflow preferences
   */
  user?: WorkflowPreferencesDto;
  /**
   * Default workflow preferences
   */
  default: WorkflowPreferencesDto1;
}
export interface WorkflowPreferencesDto {
  /**
   * A preference for the workflow. The values specified here will be used if no preference is specified for a channel.
   */
  all: WorkflowPreferenceDto & WorkflowPreferenceDto1;
  /**
   * Preferences for different communication channels
   */
  channels: {
    [k: string]: ChannelPreferenceDto;
  };
}
export interface WorkflowPreferenceDto {
  /**
   * A flag specifying if notification delivery is enabled for the workflow. If true, notification delivery is enabled by default for all channels. This setting can be overridden by the channel preferences.
   */
  enabled: boolean;
  /**
   * A flag specifying if the preference is read-only. If true, the preference cannot be changed by the Subscriber.
   */
  readOnly: boolean;
}
export interface WorkflowPreferenceDto1 {
  /**
   * A flag specifying if notification delivery is enabled for the workflow. If true, notification delivery is enabled by default for all channels. This setting can be overridden by the channel preferences.
   */
  enabled: boolean;
  /**
   * A flag specifying if the preference is read-only. If true, the preference cannot be changed by the Subscriber.
   */
  readOnly: boolean;
}
export interface ChannelPreferenceDto {
  /**
   * A flag specifying if notification delivery is enabled for the channel. If true, notification delivery is enabled.
   */
  enabled: boolean;
}
export interface WorkflowPreferencesDto1 {
  /**
   * A preference for the workflow. The values specified here will be used if no preference is specified for a channel.
   */
  all: WorkflowPreferenceDto & WorkflowPreferenceDto1;
  /**
   * Preferences for different communication channels
   */
  channels: {
    [k: string]: ChannelPreferenceDto;
  };
}
export interface RuntimeIssueDto {
  issueType:
    | "MISSING_VALUE"
    | "MAX_LENGTH_ACCESSED"
    | "WORKFLOW_ID_ALREADY_EXISTS"
    | "DUPLICATED_VALUE"
    | "LIMIT_REACHED";
  variableName?: string;
  message: string;
}
 
curl -X PUT "https://api.novu.co/v2/workflows/string/sync" \
  -H "idempotency-key: string" \
  -H "Authorization: <token>" \
  -H "Content-Type: application/json" \
  -d '{
    "targetEnvironmentId": "string"
  }'
{
  "name": "string",
  "description": "string",
  "tags": [
    "string"
  ],
  "active": false,
  "validatePayload": true,
  "payloadSchema": {},
  "isTranslationEnabled": false,
  "_id": "string",
  "workflowId": "string",
  "slug": "string",
  "updatedAt": "string",
  "createdAt": "string",
  "updatedBy": {
    "_id": "string",
    "firstName": "string",
    "lastName": "string",
    "externalId": "string"
  },
  "lastPublishedAt": "string",
  "lastPublishedBy": {
    "_id": "string",
    "firstName": "string",
    "lastName": "string",
    "externalId": "string"
  },
  "steps": [
    {
      "controls": {
        "dataSchema": {},
        "uiSchema": {
          "group": "IN_APP",
          "properties": {
            "property1": {
              "placeholder": "string",
              "component": "EMAIL_EDITOR_SELECT",
              "properties": {
                "property1": {
                  "placeholder": "string",
                  "component": "EMAIL_EDITOR_SELECT",
                  "properties": {}
                },
                "property2": {
                  "placeholder": "string",
                  "component": "EMAIL_EDITOR_SELECT",
                  "properties": {}
                }
              }
            },
            "property2": {
              "placeholder": "string",
              "component": "EMAIL_EDITOR_SELECT",
              "properties": {
                "property1": {
                  "placeholder": "string",
                  "component": "EMAIL_EDITOR_SELECT",
                  "properties": {}
                },
                "property2": {
                  "placeholder": "string",
                  "component": "EMAIL_EDITOR_SELECT",
                  "properties": {}
                }
              }
            }
          }
        },
        "values": {
          "skip": {
            "and": [
              {
                "==": [
                  {
                    "var": "payload.tier"
                  },
                  "pro"
                ]
              },
              {
                "==": [
                  {
                    "var": "subscriber.data.role"
                  },
                  "admin"
                ]
              },
              {
                ">": [
                  {
                    "var": "payload.amount"
                  },
                  "4"
                ]
              }
            ]
          },
          "body": "string",
          "subject": "string",
          "avatar": "string",
          "primaryAction": {
            "label": "string",
            "redirect": {
              "url": "string",
              "target": "_self"
            }
          },
          "secondaryAction": {
            "label": "string",
            "redirect": {
              "url": "string",
              "target": "_self"
            }
          },
          "redirect": {
            "url": "string",
            "target": "_self"
          },
          "disableOutputSanitization": false,
          "data": {}
        }
      },
      "controlValues": {
        "skip": {
          "and": [
            {
              "==": [
                {
                  "var": "payload.tier"
                },
                "pro"
              ]
            },
            {
              "==": [
                {
                  "var": "subscriber.data.role"
                },
                "admin"
              ]
            },
            {
              ">": [
                {
                  "var": "payload.amount"
                },
                "4"
              ]
            }
          ]
        },
        "body": "string",
        "subject": "string",
        "avatar": "string",
        "primaryAction": {
          "label": "string",
          "redirect": {
            "url": "string",
            "target": "_self"
          }
        },
        "secondaryAction": {
          "label": "string",
          "redirect": {
            "url": "string",
            "target": "_self"
          }
        },
        "redirect": {
          "url": "string",
          "target": "_self"
        },
        "disableOutputSanitization": false,
        "data": {}
      },
      "variables": {},
      "stepId": "string",
      "_id": "string",
      "name": "string",
      "slug": "string",
      "type": "in_app",
      "origin": "novu-cloud",
      "workflowId": "string",
      "workflowDatabaseId": "string",
      "issues": {
        "controls": {
          "property1": [
            {
              "issueType": "ILLEGAL_VARIABLE_IN_CONTROL_VALUE",
              "variableName": "string",
              "message": "string"
            }
          ],
          "property2": [
            {
              "issueType": "ILLEGAL_VARIABLE_IN_CONTROL_VALUE",
              "variableName": "string",
              "message": "string"
            }
          ]
        },
        "integration": {
          "property1": [
            {
              "issueType": "MISSING_INTEGRATION",
              "variableName": "string",
              "message": "string"
            }
          ],
          "property2": [
            {
              "issueType": "MISSING_INTEGRATION",
              "variableName": "string",
              "message": "string"
            }
          ]
        }
      }
    }
  ],
  "origin": "novu-cloud",
  "preferences": {
    "user": {
      "all": {
        "enabled": true,
        "readOnly": false
      },
      "channels": {
        "email": {
          "enabled": true
        },
        "sms": {
          "enabled": false
        }
      }
    },
    "default": {
      "all": {
        "enabled": true,
        "readOnly": false
      },
      "channels": {
        "email": {
          "enabled": true
        },
        "sms": {
          "enabled": false
        }
      }
    }
  },
  "status": "ACTIVE",
  "issues": {
    "property1": {
      "issueType": "MISSING_VALUE",
      "variableName": "string",
      "message": "string"
    },
    "property2": {
      "issueType": "MISSING_VALUE",
      "variableName": "string",
      "message": "string"
    }
  },
  "lastTriggeredAt": "string",
  "payloadExample": {},
  "severity": "high"
}

On this page

No Headings
Edit this page on GitHub