We use cookies

We use cookies to ensure you get the best experience on our website. For more information on how we use cookies, please see our cookie policy.

By clicking "Accept", you agree to our use of cookies.
Learn more.

SDK ReferencePython SDKClient

Hatchet Python SDK Reference

This is the Python SDK reference, documenting methods available for interacting with Hatchet resources. Check out the user guide for an introduction for getting your first tasks running.

The Hatchet Python Client

Main client for interacting with the Hatchet SDK.

This class provides access to various client interfaces and utility methods for working with Hatchet workers, workflows, tasks, and our various feature clients.

Methods:

NameDescription
workerCreate a Hatchet worker on which to run workflows.
workflowDefine a Hatchet workflow, which can then declare tasks and be run, scheduled, and so on.
taskA decorator to transform a function into a standalone Hatchet task that runs as part of a workflow.
durable_taskA decorator to transform a function into a standalone Hatchet durable task that runs as part of a workflow.

Attributes

cron

The cron client is a client for managing cron workflows within Hatchet.

event

The event client, which you can use to push events to Hatchet.

logs

The logs client is a client for interacting with Hatchet’s logs API.

metrics

The metrics client is a client for reading metrics out of Hatchet’s metrics API.

rate_limits

The rate limits client is a wrapper for Hatchet’s gRPC API that makes it easier to work with rate limits in Hatchet.

runs

The runs client is a client for interacting with task and workflow runs within Hatchet.

scheduled

The scheduled client is a client for managing scheduled workflows within Hatchet.

workers

The workers client is a client for managing workers programmatically within Hatchet.

workflows

The workflows client is a client for managing workflows programmatically within Hatchet.

Note that workflows are the declaration, not the individual runs. If you’re looking for runs, use the RunsClient instead.

tenant_id

The tenant id you’re operating in.

namespace

The current namespace you’re interacting with.

Functions

worker

Create a Hatchet worker on which to run workflows.

Parameters:

NameTypeDescriptionDefault
namestrThe name of the worker.required
slotsintThe number of workflow slots on the worker. In other words, the number of concurrent tasks the worker can run at any point in time.100
durable_slotsintThe number of durable workflow slots on the worker. In other words, the number of concurrent tasks the worker can run at any point in time that are durable.1000
labelsdict[str, str | int] | NoneA dictionary of labels to assign to the worker. For more details, view examples on affinity and worker labels.None
workflowslist[BaseWorkflow[Any]] | NoneA list of workflows to register on the worker, as a shorthand for calling register_workflow on each or register_workflows on all of them.None
lifespanLifespanFn | NoneA lifespan function to run on the worker. This function will be called when the worker is started, and can be used to perform any setup or teardown tasks.None

Returns:

TypeDescription
WorkerThe created Worker object, which exposes an instance method start which can be called to start the worker.

workflow

Define a Hatchet workflow, which can then declare tasks and be run, scheduled, and so on.

Parameters:

NameTypeDescriptionDefault
namestrThe name of the workflow.required
descriptionstr | NoneA description for the workflow.None
input_validatortype[TWorkflowInput] | NoneA Pydantic model to use as a validator for the input to the tasks in the workflow. If no validator is provided, defaults to an EmptyModel under the hood. The EmptyModel is a Pydantic model with no fields specified, and with the extra config option set to "allow".None
on_eventslist[str] | NoneA list of event triggers for the workflow - events which cause the workflow to be run.None
on_cronslist[str] | NoneA list of cron triggers for the workflow.None
versionstr | NoneA version for the workflow.None
stickyStickyStrategy | NoneA sticky strategy for the workflow.None
default_priorityintThe priority of the workflow. Higher values will cause this workflow to have priority in scheduling over other, lower priority ones.1
concurrencyConcurrencyExpression | list[ConcurrencyExpression] | NoneA concurrency object controlling the concurrency settings for this workflow.None
task_defaultsTaskDefaultsA TaskDefaults object controlling the default task settings for this workflow.TaskDefaults()
default_filterslist[DefaultFilter] | NoneA list of filters to create with the workflow is created. Note that this is a helper to allow you to create filters “declaratively” without needing to make a separate API call once the workflow is created to create them.None

Returns:

TypeDescription
Workflow[EmptyModel] | Workflow[TWorkflowInput]The created Workflow object, which can be used to declare tasks, run the workflow, and so on.

task

A decorator to transform a function into a standalone Hatchet task that runs as part of a workflow.

Parameters:

NameTypeDescriptionDefault
namestr | NoneThe name of the task. If not specified, defaults to the name of the function being wrapped by the task decorator.None
descriptionstr | NoneAn optional description for the task.None
input_validatortype[TWorkflowInput] | NoneA Pydantic model to use as a validator for the input to the task. If no validator is provided, defaults to an EmptyModel.None
on_eventslist[str] | NoneA list of event triggers for the task - events which cause the task to be run.None
on_cronslist[str] | NoneA list of cron triggers for the task.None
versionstr | NoneA version for the task.None
stickyStickyStrategy | NoneA sticky strategy for the task.None
default_priorityintThe priority of the task. Higher values will cause this task to have priority in scheduling.1
concurrencyConcurrencyExpression | list[ConcurrencyExpression] | NoneA concurrency object controlling the concurrency settings for this task.None
schedule_timeoutDurationThe maximum time allowed for scheduling the task.timedelta(minutes=5)
execution_timeoutDurationThe maximum time allowed for executing the task.timedelta(seconds=60)
retriesintThe number of times to retry the task before failing.0
rate_limitslist[RateLimit] | NoneA list of rate limit configurations for the task.None
desired_worker_labelsdict[str, DesiredWorkerLabel] | NoneA dictionary of desired worker labels that determine to which worker the task should be assigned.None
backoff_factorfloat | NoneThe backoff factor for controlling exponential backoff in retries.None
backoff_max_secondsint | NoneThe maximum number of seconds to allow retries with exponential backoff to continue.None
default_filterslist[DefaultFilter] | NoneA list of filters to create with the task is created. Note that this is a helper to allow you to create filters “declaratively” without needing to make a separate API call once the task is created to create them.None

Returns:

TypeDescription
Callable[[Callable[[EmptyModel, Context], R | CoroutineLike[R]]], Standalone[EmptyModel, R]] | Callable[[Callable[[TWorkflowInput, Context], R | CoroutineLike[R]]], Standalone[TWorkflowInput, R]]A decorator which creates a Standalone task object.

durable_task

A decorator to transform a function into a standalone Hatchet durable task that runs as part of a workflow.

Parameters:

NameTypeDescriptionDefault
namestr | NoneThe name of the task. If not specified, defaults to the name of the function being wrapped by the task decorator.None
descriptionstr | NoneAn optional description for the task.None
input_validatortype[TWorkflowInput] | NoneA Pydantic model to use as a validator for the input to the task. If no validator is provided, defaults to an EmptyModel.None
on_eventslist[str] | NoneA list of event triggers for the task - events which cause the task to be run.None
on_cronslist[str] | NoneA list of cron triggers for the task.None
versionstr | NoneA version for the task.None
stickyStickyStrategy | NoneA sticky strategy for the task.None
default_priorityintThe priority of the task. Higher values will cause this task to have priority in scheduling.1
concurrencyConcurrencyExpression | list[ConcurrencyExpression] | NoneA concurrency object controlling the concurrency settings for this task.None
schedule_timeoutDurationThe maximum time allowed for scheduling the task.timedelta(minutes=5)
execution_timeoutDurationThe maximum time allowed for executing the task.timedelta(seconds=60)
retriesintThe number of times to retry the task before failing.0
rate_limitslist[RateLimit] | NoneA list of rate limit configurations for the task.None
desired_worker_labelsdict[str, DesiredWorkerLabel] | NoneA dictionary of desired worker labels that determine to which worker the task should be assigned.None
backoff_factorfloat | NoneThe backoff factor for controlling exponential backoff in retries.None
backoff_max_secondsint | NoneThe maximum number of seconds to allow retries with exponential backoff to continue.None
default_filterslist[DefaultFilter] | NoneA list of filters to create with the task is created. Note that this is a helper to allow you to create filters “declaratively” without needing to make a separate API call once the task is created to create them.None

Returns:

TypeDescription
Callable[[Callable[[EmptyModel, DurableContext], R | CoroutineLike[R]]], Standalone[EmptyModel, R]] | Callable[[Callable[[TWorkflowInput, DurableContext], R | CoroutineLike[R]]], Standalone[TWorkflowInput, R]]A decorator which creates a Standalone task object.