Documentation ¶
Index ¶
- Constants
- type Action
- type ActionEvent
- type ActionEventResponse
- type ActionEventType
- type ActionPayload
- type ActionType
- type AdminClient
- type BulkPushOpFunc
- type ChildWorkflowOpts
- type Client
- type ClientEventListener
- type ClientOpt
- func InitWorkflows() ClientOpt
- func WithHostPort(host string, port int) ClientOpt
- func WithLogLevel(lvl string) ClientOpt
- func WithNamespace(namespace string) ClientOpt
- func WithSharedMeta(meta map[string]string) ClientOpt
- func WithTenantId(tenantId string) ClientOpt
- func WithToken(token string) ClientOpt
- func WithWorkflows(files []*types.Workflow) ClientOpt
- type ClientOpts
- type CronClient
- type CronOpts
- type DedupeViolationErr
- type DispatcherClient
- type EventClient
- type EventWithAdditionalMetadata
- type GetActionListenerRequest
- type ListenerStrategy
- type PushOpFunc
- type PutOptFunc
- type RunChildWorkflowsOpts
- type RunHandler
- type RunOptFunc
- type ScheduleClient
- type ScheduleOptFunc
- type ScheduleOpts
- type StreamEvent
- type StreamHandler
- type SubscribeClient
- type WorkerActionListener
- type Workflow
- type WorkflowEvent
- type WorkflowResult
- type WorkflowRun
- type WorkflowRunEvent
- type WorkflowRunEventHandler
- type WorkflowRunsListener
Constants ¶
View Source
const ( DefaultActionListenerRetryInterval = 5 * time.Second DefaultActionListenerRetryCount = 5 )
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Action ¶
type Action struct { // the worker id WorkerId string `json:"workerId"` // the tenant id TenantId string `json:"tenantId"` // the workflow run id WorkflowRunId string `json:"workflowRunId"` // the get group key run id GetGroupKeyRunId string `json:"getGroupKeyRunId"` // the job id JobId string `json:"jobId"` // the job name JobName string `json:"jobName"` // the job run id JobRunId string `json:"jobRunId"` // the step id StepId string `json:"stepId"` // the step name StepName string `json:"stepName"` // the step run id StepRunId string `json:"stepRunId"` // the action id ActionId string `json:"actionId"` // the action payload ActionPayload []byte `json:"actionPayload"` // the action type ActionType ActionType `json:"actionType"` // the count of the retry attempt RetryCount int32 `json:"retryCount"` // the additional metadata for the workflow run AdditionalMetadata map[string]string // the child index for the workflow run ChildIndex *int32 // the child key for the workflow run ChildKey *string // the parent workflow run id ParentWorkflowRunId *string }
type ActionEvent ¶
type ActionEvent struct { *Action // the event timestamp EventTimestamp *time.Time // the step event type EventType ActionEventType // The event payload. This must be JSON-compatible as it gets marshalled to a JSON string. EventPayload interface{} }
type ActionEventResponse ¶
type ActionEventType ¶
type ActionEventType string
const ( ActionEventTypeUnknown ActionEventType = "STEP_EVENT_TYPE_UNKNOWN" ActionEventTypeStarted ActionEventType = "STEP_EVENT_TYPE_STARTED" ActionEventTypeCompleted ActionEventType = "STEP_EVENT_TYPE_COMPLETED" ActionEventTypeFailed ActionEventType = "STEP_EVENT_TYPE_FAILED" )
type ActionPayload ¶
type ActionPayload func(target interface{}) error
ActionPayload unmarshals the action payload into the target. It also validates the resulting target.
type ActionType ¶
type ActionType string
const ( ActionTypeStartStepRun ActionType = "START_STEP_RUN" ActionTypeCancelStepRun ActionType = "CANCEL_STEP_RUN" ActionTypeStartGetGroupKey ActionType = "START_GET_GROUP_KEY" )
type AdminClient ¶
type AdminClient interface { PutWorkflow(workflow *types.Workflow, opts ...PutOptFunc) error ScheduleWorkflow(workflowName string, opts ...ScheduleOptFunc) error // RunWorkflow triggers a workflow run and returns the run id RunWorkflow(workflowName string, input interface{}, opts ...RunOptFunc) (*Workflow, error) BulkRunWorkflow(workflows []*WorkflowRun) ([]string, error) RunChildWorkflow(workflowName string, input interface{}, opts *ChildWorkflowOpts) (string, error) RunChildWorkflows(workflows []*RunChildWorkflowsOpts) ([]string, error) PutRateLimit(key string, opts *types.RateLimitOpts) error }
type BulkPushOpFunc ¶ added in v0.46.0
type BulkPushOpFunc func(*eventcontracts.BulkPushEventRequest) error
type ChildWorkflowOpts ¶ added in v0.18.0
type Client ¶
type Client interface { Admin() AdminClient Cron() CronClient Schedule() ScheduleClient Dispatcher() DispatcherClient Event() EventClient Subscribe() SubscribeClient API() *rest.ClientWithResponses CloudAPI() *cloudrest.ClientWithResponses TenantId() string Namespace() string CloudRegisterID() *string RunnableActions() []string }
func NewFromConfigFile ¶ added in v0.11.0
func NewFromConfigFile(cf *client.ClientConfigFile, fs ...ClientOpt) (Client, error)
type ClientEventListener ¶ added in v0.9.0
type ClientEventListener interface {
OnWorkflowEvent(ctx context.Context, event *WorkflowEvent) error
}
type ClientOpt ¶
type ClientOpt func(*ClientOpts)
func InitWorkflows ¶
func InitWorkflows() ClientOpt
func WithHostPort ¶
func WithLogLevel ¶ added in v0.18.1
func WithNamespace ¶ added in v0.20.2
func WithSharedMeta ¶ added in v0.52.12
func WithTenantId ¶
func WithWorkflows ¶
WithWorkflows sets the workflow files to use for the worker. If this is not passed in, the workflows files will be loaded from the .hatchet folder in the current directory.
type ClientOpts ¶
type ClientOpts struct {
// contains filtered or unexported fields
}
type CronClient ¶ added in v0.52.5
type CronClient interface { // Create creates a new cron trigger Create(ctx context.Context, workflow string, opts *CronOpts) (*gen.CronWorkflows, error) // Delete deletes a cron trigger Delete(ctx context.Context, id string) error // List lists all cron triggers List(ctx context.Context) (*gen.CronWorkflowsList, error) }
func NewCronClient ¶ added in v0.52.5
func NewCronClient(restClient *rest.ClientWithResponses, l *zerolog.Logger, v validator.Validator, tenantId, namespace string) (CronClient, error)
type CronOpts ¶ added in v0.52.5
type CronOpts struct { // Name is the user-friendly name for the cron trigger Name string // Expression is the cron expression for the trigger Expression string // Input is the input to the workflow Input map[string]interface{} // AdditionalMetadata is additional metadata to be stored with the cron trigger AdditionalMetadata map[string]string }
type DedupeViolationErr ¶ added in v0.40.0
type DedupeViolationErr struct {
// contains filtered or unexported fields
}
func (*DedupeViolationErr) Error ¶ added in v0.40.0
func (d *DedupeViolationErr) Error() string
type DispatcherClient ¶
type DispatcherClient interface { GetActionListener(ctx context.Context, req *GetActionListenerRequest) (WorkerActionListener, *string, error) SendStepActionEvent(ctx context.Context, in *ActionEvent) (*ActionEventResponse, error) SendGroupKeyActionEvent(ctx context.Context, in *ActionEvent) (*ActionEventResponse, error) ReleaseSlot(ctx context.Context, stepRunId string) error RefreshTimeout(ctx context.Context, stepRunId string, incrementTimeoutBy string) error UpsertWorkerLabels(ctx context.Context, workerId string, labels map[string]interface{}) error }
type EventClient ¶
type EventClient interface { Push(ctx context.Context, eventKey string, payload interface{}, options ...PushOpFunc) error BulkPush(ctx context.Context, payloads []EventWithAdditionalMetadata, options ...BulkPushOpFunc) error PutLog(ctx context.Context, stepRunId, msg string) error PutStreamEvent(ctx context.Context, stepRunId string, message []byte) error }
type EventWithAdditionalMetadata ¶ added in v0.50.0
type GetActionListenerRequest ¶
type GetActionListenerRequest struct { WorkerName string Services []string Actions []string MaxRuns *int Labels map[string]interface{} WebhookId *string }
TODO: add validator to client side
type ListenerStrategy ¶ added in v0.18.1
type ListenerStrategy string
const ( ListenerStrategyV1 ListenerStrategy = "v1" ListenerStrategyV2 ListenerStrategy = "v2" )
type PushOpFunc ¶ added in v0.25.0
type PushOpFunc func(*pushOpt) error
func WithEventMetadata ¶ added in v0.25.0
func WithEventMetadata(metadata map[string]string) PushOpFunc
type PutOptFunc ¶
type PutOptFunc func(*putOpts)
type RunChildWorkflowsOpts ¶ added in v0.50.0
type RunChildWorkflowsOpts struct { WorkflowName string Input interface{} Opts *ChildWorkflowOpts }
type RunHandler ¶ added in v0.9.0
type RunHandler func(event WorkflowEvent) error
type RunOptFunc ¶ added in v0.25.0
type RunOptFunc func(*admincontracts.TriggerWorkflowRequest) error
func WithRunMetadata ¶ added in v0.25.0
func WithRunMetadata(metadata interface{}) RunOptFunc
type ScheduleClient ¶ added in v0.52.5
type ScheduleClient interface { // Create creates a new scheduled workflow run Create(ctx context.Context, workflow string, opts *ScheduleOpts) (*gen.ScheduledWorkflows, error) // Delete deletes a scheduled workflow run Delete(ctx context.Context, id string) error // List lists all scheduled workflow runs List(ctx context.Context) (*gen.ScheduledWorkflowsList, error) }
func NewScheduleClient ¶ added in v0.52.5
func NewScheduleClient(restClient *rest.ClientWithResponses, l *zerolog.Logger, v validator.Validator, tenantId, namespace string) (ScheduleClient, error)
type ScheduleOptFunc ¶
type ScheduleOptFunc func(*scheduleOpts)
func WithInput ¶
func WithInput(input any) ScheduleOptFunc
func WithSchedules ¶
func WithSchedules(schedules ...time.Time) ScheduleOptFunc
type ScheduleOpts ¶ added in v0.52.5
type ScheduleOpts struct { // TriggerAt is the time at which the scheduled run should be triggered TriggerAt time.Time // Input is the input to the workflow Input map[string]interface{} // AdditionalMetadata is additional metadata to be stored with the cron trigger AdditionalMetadata map[string]string }
type StreamEvent ¶ added in v0.19.0
type StreamEvent struct {
Message []byte
}
type StreamHandler ¶ added in v0.19.0
type StreamHandler func(event StreamEvent) error
type SubscribeClient ¶ added in v0.19.0
type SubscribeClient interface { On(ctx context.Context, workflowRunId string, handler RunHandler) error Stream(ctx context.Context, workflowRunId string, handler StreamHandler) error StreamByAdditionalMetadata(ctx context.Context, key string, value string, handler StreamHandler) error SubscribeToWorkflowRunEvents(ctx context.Context) (*WorkflowRunsListener, error) }
type WorkerActionListener ¶
type Workflow ¶ added in v0.50.0
type Workflow struct {
// contains filtered or unexported fields
}
func NewWorkflow ¶ added in v0.50.0
func NewWorkflow( workflowRunId string, listener *WorkflowRunsListener, ) *Workflow
func (*Workflow) Result ¶ added in v0.50.0
func (c *Workflow) Result() (*WorkflowResult, error)
func (*Workflow) WorkflowRunId ¶ added in v0.50.0
type WorkflowEvent ¶ added in v0.21.0
type WorkflowEvent *dispatchercontracts.WorkflowEvent
type WorkflowResult ¶ added in v0.50.0
type WorkflowResult struct {
// contains filtered or unexported fields
}
func (*WorkflowResult) StepOutput ¶ added in v0.50.0
func (r *WorkflowResult) StepOutput(key string, v interface{}) error
type WorkflowRun ¶ added in v0.50.0
type WorkflowRun struct { Name string Input interface{} Options []RunOptFunc }
type WorkflowRunEvent ¶ added in v0.21.0
type WorkflowRunEvent *dispatchercontracts.WorkflowRunEvent
type WorkflowRunEventHandler ¶ added in v0.21.0
type WorkflowRunEventHandler func(event WorkflowRunEvent) error
type WorkflowRunsListener ¶ added in v0.21.0
type WorkflowRunsListener struct {
// contains filtered or unexported fields
}
func (*WorkflowRunsListener) AddWorkflowRun ¶ added in v0.21.0
func (l *WorkflowRunsListener) AddWorkflowRun( workflowRunId string, handler WorkflowRunEventHandler, ) error
func (*WorkflowRunsListener) Close ¶ added in v0.21.0
func (l *WorkflowRunsListener) Close() error
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
cloud
|
|
rest
Package rest provides primitives to interact with the openapi HTTP API.
|
Package rest provides primitives to interact with the openapi HTTP API. |
Package rest provides primitives to interact with the openapi HTTP API.
|
Package rest provides primitives to interact with the openapi HTTP API. |
Click to show internal directories.
Click to hide internal directories.