Contexts
DBOS provides a number of useful context methods and variables.
All are accessed through the syntax DBOS.<method>
and can only be used once a DBOS class object has been initialized.
Context Methods
send
DBOS.send(
destination_id: str,
message: Any,
topic: Optional[str] = None
) -> None
Send a message to the workflow identified by destination_id
.
Messages can optionally be associated with a topic.
The send
function should not be used in coroutine workflows, send_async
should be used instead.
Parameters:
destination_id
: The workflow to which to send the message.message
: The message to send. Must be serializable.topic
: A topic with which to associate the message. Messages are enqueued per-topic on the receiver.
send_async
DBOS.send_async(
destination_id: str,
message: Any,
topic: Optional[str] = None
) -> Coroutine[Any, Any, None]
Coroutine version of send
recv
DBOS.recv(
topic: Optional[str] = None,
timeout_seconds: float = 60,
) -> Any
Receive and return a message sent to this workflow.
Can only be called from within a workflow.
Messages are dequeued first-in, first-out from a queue associated with the topic.
Calls to recv
wait for the next message in the queue, returning None
if the wait times out.
If no topic is specified, recv
can only access messages sent without a topic.
The recv
function should not be used in coroutine workflows, recv_async
should be used instead.
Parameters:
topic
: A topic queue on which to wait.timeout_seconds
: A timeout in seconds. If the wait times out, returnNone
.
Returns:
- The first message enqueued on the input topic, or
None
if the wait times out.
recv_async
DBOS.recv_async(
topic: Optional[str] = None,
timeout_seconds: float = 60,
) -> Coroutine[Any, Any, Any]
Coroutine version of recv
set_event
DBOS.set_event(
key: str,
value: Any,
) -> None
Create and associate with this workflow an event with key key
and value value
.
If the event already exists, update its value.
Can only be called from within a workflow.
The set_event
function should not be used in coroutine workflows, set_event_async
should be used instead.
Parameters:
key
: The key of the event.value
: The value of the event. Must be serializable.
set_event_async
DBOS.set_event(
key: str,
value: Any,
) -> Coroutine[Any, Any, None]
Coroutine version of set_event
get_event
DBOS.get_event(
workflow_id: str,
key: str,
timeout_seconds: float = 60,
) -> Any
Retrieve the latest value of an event published by the workflow identified by workflow_id
to the key key
.
If the event does not yet exist, wait for it to be published, returning None
if the wait times out.
The get_event
function should not be used in coroutine workflows, get_event_async
should be used instead.
Parameters:
workflow_id
: The identifier of the workflow whose events to retrieve.key
: The key of the event to retrieve.timeout_seconds
: A timeout in seconds. If the wait times out, returnNone
.
Returns:
- The value of the event published by
workflow_id
with namekey
, orNone
if the wait times out.
get_event_async
DBOS.get_event_async(
workflow_id: str,
key: str,
timeout_seconds: float = 60,
) -> Coroutine[Any, Any, Any]
Coroutine version of get_event
sleep
DBOS.sleep(
seconds: float
) -> None
Sleep for the given number of seconds.
May only be called from within a workflow.
This sleep is durable—it records its intended wake-up time in the database so if it is interrupted and recovers, it still wakes up at the intended time.
The sleep
function should not be used in coroutine workflows, sleep_async
should be used instead.
Parameters:
seconds
: The number of seconds to sleep.
sleep_async
DBOS.sleep_async(
seconds: float
) -> Coroutine[Any, Any, None]
Coroutine version of sleep
retrieve_workflow
DBOS.retrieve_workflow(
workflow_id: str,
existing_workflow: bool = True,
) -> WorkflowHandle[R]
Retrieve the handle of a workflow with identity workflow_id
.
Parameters:
workflow_id
: The identifier of the workflow whose handle to retrieve.existing_workflow
: Whether to throw an exception if the workflow does not yet exist, or to wait for its creation. If set toFalse
and the workflow does not exist, will wait for the workflow to be created, then return its handle.
Returns:
- The handle of the workflow whose ID is
workflow_id
.
start_workflow
DBOS.start_workflow(
func: Workflow[P, R],
*args: P.args,
**kwargs: P.kwargs,
) -> WorkflowHandle[R]
Start a workflow in the background and return a handle to it.
The DBOS.start_workflow
method resolves after the handle is durably created; at this point the workflow is guaranteed to run to completion even if the app is interrupted.
Example syntax:
@DBOS.workflow()
def example_workflow(var1: str, var2: str):
DBOS.logger.info("I am a workflow")
# Start example_workflow in the background
handle: WorkflowHandle = DBOS.start_workflow(example_workflow, "var1", "var2")
Context Variables
logger
DBOS.logger: Logger
Retrieve the DBOS logger. This is a pre-configured Python logger provided as a convenience.
sql_session
DBOS.sql_session: sqlalchemy.Session
May only be accessed from within a transaction. Retrieves the SQLAlchemy session of the transaction, a database connection the transaction can use to interact with the database.
DBOS automatically wraps your transaction functions in a SQLAlchemy "begin once" block. Transaction functions automatically commit when they successfully complete and roll back if they throw an exception. Therefore, do not use DBOS.sql_session.commit()
or DBOS.sql_session.rollback()
in your transaction functions. Otherwise, you might see a sqlalchemy.exc.InvalidRequestError: Can't operate on closed transaction inside context manager
error.
workflow_id
DBOS.workflow_id: str
May only be accessed from within a workflow, step, or transaction. Return the identity of the current workflow.
span
DBOS.span: opentelemetry.trace.Span
Retrieve the OpenTelemetry span associated with the curent request. You can use this to set custom attributes in your span.
request
DBOS.request: Request
May only be accessed from within the handler of a FastAPI request, or in a function called from the handler. Retrieve request information parsed from FastAPI:
headers: Headers # The request headers
path_params: dict[str, Any] # The request's path parameters
query_params QueryParams # The request's query parameters
url: URL # The URL to which the request was sent
base_url: URL # The base URL of the request
client: Optional[Address] # Information about the client that sent the request
cookies: dict[str, str] # The request's cookie parameters
method: str # The HTTP method of the request
config
DBOS.config: ConfigFile
Return the current DBOS configuration, as a ConfigFile
.
Authentication
authenticated_user
DBOS.authenticated_user: Optional[str]
Return the current authenticated user, if any, associated with the current context.
authenticated_roles
DBOS.authenticated_roles: Optional[List[str]]
Return the roles granted to the current authenticated user, if any, associated with the current context.
assumed_role
DBOS.assumed_role: Optional[str]
Return the role currently assumed by the authenticated user, if any, associated with the current context.
set_authentication
DBOS.set_authentication(
authenticated_user: Optional[str],
authenticated_roles: Optional[List[str]]
) -> None
Set the current authenticated user and granted roles into the current context. This would generally be done by HTTP middleware
Context Management
SetWorkflowID
SetWorkflowID(
wfid: str
)
Set the workflow ID/idempotency key of the next workflow to run.
Should be used in a with
statement.
Example syntax:
@DBOS.workflow()
def example_workflow():
DBOS.logger.info(f"I am a workflow with ID {DBOS.workflow_id}")
# The workflow will run with the supplied ID
with SetWorkflowID("very-unique-id"):
example_workflow()
DBOSContextEnsure
DBOSContextEnsure()
# Code inside will run with a DBOS context available
with DBOSContextEnsure():
# Call DBOS functions
pass
Use of DBOSContextEnsure
ensures that there is a DBOS context associated with the enclosed code prior to calling DBOS functions. DBOSContextEnsure
is generally not used by applications directly, but used by event dispatchers, HTTP server middleware, etc., to set up the DBOS context prior to entry into function calls.
DBOSContextSetAuth
DBOSContextSetAuth(user: Optional[str], roles: Optional[List[str]])
# Code inside will run with `curuser` and `curroles`
with DBOSContextSetAuth(curuser, curroles):
# Call DBOS functions
pass
with DBOSContextSetAuth
sets the current authorized user and roles for the code inside the with
block. Similar to DBOSContextEnsure
, DBOSContextSetAuth
also ensures that there is a DBOS context associated with the enclosed code prior to calling DBOS functions.
DBOSContextSetAuth
is generally not used by applications directly, but used by event dispatchers, HTTP server middleware, etc., to set up the DBOS context prior to entry into function calls.