Skip to main content

Workflow Handles

A workflow handle represents the state of a particular active or completed workflow execution. A workflow handle is obtained when a workflow is started with DBOS.startWorkflow. Additionally, a handle can be retrieved by calling DBOS.retrieveWorkflow with the workflow's unique ID.


Methods

getStatus(): Promise<WorkflowStatus>

Retrieves the status of a workflow with the following structure:

export interface WorkflowStatus {
readonly status: string; // The status of the workflow. One of PENDING, SUCCESS, ERROR, RETRIES_EXCEEDED, or CANCELLED.
readonly workflowName: string; // The name of the workflow function.
readonly authenticatedUser: string; // The user who ran the workflow. Empty string if not set.
readonly assumedRole: string; // The role used to run this workflow. Empty string if authorization is not required.
readonly authenticatedRoles: string[]; // All roles the authenticated user has, if any.
readonly request: HTTPRequest; // The parent request for this workflow, if any.
}

getResult(): Promise<R>

Waits for the workflow to complete then returns its output.

workflowID: string

Retrieves the workflow's unique ID.

getWorkflowInputs<T extends any []>(): Promise<T>

Retrieves the worklow's input argument array.