services

package
v1.0.335 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 5, 2022 License: MIT Imports: 24 Imported by: 0

Documentation

Index

Constants

View Source
const (
	AbortTypeActivity    = iota // AbortTypeActivity signifies an activity is being aborted
	AbortTypeServiceTask = iota // AbortTypeServiceTask signifies a service task is being aborted
)

Variables

This section is empty.

Functions

func WithEmbargo added in v1.0.215

func WithEmbargo(embargo int) *publishEmbargoOption

WithEmbargo allows the specification of an embargo time on a workflow state message

Types

type AbortFunc added in v1.0.251

type AbortFunc func(ctx context.Context, abort AbortType, state *model.WorkflowState) (bool, error)

AbortFunc is the callback function type called when a workflow object aborts.

type AbortType added in v1.0.251

type AbortType int

AbortType represents the type of termination being handled by the abort function

type CompleteActivityFunc added in v1.0.235

type CompleteActivityFunc func(ctx context.Context, trackingId common.TrackingID, el *model.Element, wfi *model.WorkflowInstance, cancellationState model.CancellationState, vrs []byte) error

CompleteActivityFunc is the callback function type which generates complete activity events.

type CompleteActivityProcessorFunc added in v1.0.215

type CompleteActivityProcessorFunc func(ctx context.Context, activity *model.WorkflowState) error

CompleteActivityProcessorFunc is the callback function type fired when an activity completes.

type CompleteJobProcessorFunc

type CompleteJobProcessorFunc func(ctx context.Context, job *model.WorkflowState) error

CompleteJobProcessorFunc is the callback function type for completed tasks.

type EventProcessorFunc

type EventProcessorFunc func(ctx context.Context, newActivityID string, traversal *model.WorkflowState, traverseOnly bool) error

EventProcessorFunc is the callback function type for processing workflow activities.

type LaunchFunc added in v1.0.215

type LaunchFunc func(ctx context.Context, state *model.WorkflowState) error

LaunchFunc is the callback function type used to start child workflows.

type MessageCompleteProcessorFunc

type MessageCompleteProcessorFunc func(ctx context.Context, state *model.WorkflowState) error

MessageCompleteProcessorFunc is the callback function type for completed messages.

type MessageProcessorFunc added in v1.0.224

type MessageProcessorFunc func(ctx context.Context, state *model.WorkflowState) (bool, int, error)

MessageProcessorFunc is the callback function type used to create new workflow instances based on a timer.

type NatsService

type NatsService struct {
	// contains filtered or unexported fields
}

NatsService contains the engine functions that communicate with NATS.

func NewNatsService

func NewNatsService(conn common.NatsConn, txConn common.NatsConn, storageType nats.StorageType, concurrency int, allowOrphanServiceTasks bool) (*NatsService, error)

NewNatsService creates a new instance of the NATS communication layer.

func (*NatsService) AwaitMsg

func (s *NatsService) AwaitMsg(ctx context.Context, state *model.WorkflowState) error

AwaitMsg sets up a message subscription to wait for a workflow message

func (*NatsService) CloseUserTask added in v0.1.86

func (s *NatsService) CloseUserTask(ctx context.Context, trackingID string) error

CloseUserTask removes a completed user task.

func (*NatsService) Conn

func (s *NatsService) Conn() common.NatsConn

Conn returns the active nats connection

func (*NatsService) CreateJob

func (s *NatsService) CreateJob(ctx context.Context, job *model.WorkflowState) (string, error)

CreateJob stores a workflow task state.

func (*NatsService) CreateWorkflowInstance

func (s *NatsService) CreateWorkflowInstance(ctx context.Context, wfInstance *model.WorkflowInstance) (*model.WorkflowInstance, error)

CreateWorkflowInstance given a workflow, starts a new workflow instance and returns its ID

func (*NatsService) DeleteJob added in v1.0.215

func (s *NatsService) DeleteJob(_ context.Context, trackingID string) error

DeleteJob removes a workflow task state.

func (*NatsService) DestroyWorkflowInstance

func (s *NatsService) DestroyWorkflowInstance(ctx context.Context, workflowInstanceID string, state model.CancellationState, wfError *model.Error) error

DestroyWorkflowInstance terminates a running workflow instance with a cancellation reason and error

func (*NatsService) GetElement added in v0.1.175

func (s *NatsService) GetElement(ctx context.Context, state *model.WorkflowState) (*model.Element, error)

GetElement gets the definition for the current element given a workflow state.

func (*NatsService) GetJob

func (s *NatsService) GetJob(ctx context.Context, trackingID string) (*model.WorkflowState, error)

GetJob gets a workflow task state.

func (*NatsService) GetLatestVersion

func (s *NatsService) GetLatestVersion(ctx context.Context, workflowName string) (string, error)

GetLatestVersion queries the workflow versions table for the latest entry

func (*NatsService) GetMessageSenderRoutingKey added in v0.1.167

func (s *NatsService) GetMessageSenderRoutingKey(ctx context.Context, workflowName string, messageName string) (string, error)

GetMessageSenderRoutingKey gets an ID used to listen for workflow message instances.

func (*NatsService) GetOldState added in v1.0.215

func (s *NatsService) GetOldState(ctx context.Context, id string) (*model.WorkflowState, error)

GetOldState gets a task state given its tracking ID.

func (*NatsService) GetServiceTaskRoutingKey added in v0.1.167

func (s *NatsService) GetServiceTaskRoutingKey(ctx context.Context, taskName string) (string, error)

GetServiceTaskRoutingKey gets a unique ID for a service task that can be used to listen for its activation.

func (*NatsService) GetUserTaskIDs added in v0.1.86

func (s *NatsService) GetUserTaskIDs(ctx context.Context, owner string) (*model.UserTasks, error)

GetUserTaskIDs gets a list of tasks given an owner.

func (*NatsService) GetWorkflow

func (s *NatsService) GetWorkflow(ctx context.Context, workflowID string) (*model.Workflow, error)

GetWorkflow retrieves a workflow model given its ID

func (*NatsService) GetWorkflowInstance

func (s *NatsService) GetWorkflowInstance(ctx context.Context, workflowInstanceID string) (*model.WorkflowInstance, error)

GetWorkflowInstance retrieves workflow instance given its ID.

func (*NatsService) GetWorkflowInstanceStatus

func (s *NatsService) GetWorkflowInstanceStatus(ctx context.Context, id string) (*model.WorkflowInstanceStatus, error)

GetWorkflowInstanceStatus gets the current status for a workflow instance.

func (*NatsService) ListWorkflowInstance

func (s *NatsService) ListWorkflowInstance(ctx context.Context, workflowName string) (chan *model.ListWorkflowInstanceResult, chan error)

ListWorkflowInstance returns a list of running workflows and versions given a workflow ID

func (*NatsService) ListWorkflows

func (s *NatsService) ListWorkflows(ctx context.Context) (chan *model.ListWorkflowResult, chan error)

ListWorkflows returns a list of all the workflows in SHAR.

func (*NatsService) OwnerID added in v1.0.272

func (s *NatsService) OwnerID(name string) (string, error)

OwnerID gets a unique identifier for a task owner.

func (*NatsService) OwnerName added in v0.1.86

func (s *NatsService) OwnerName(id string) (string, error)

OwnerName retrieves an owner name given an ID.

func (*NatsService) PublishMessage

func (s *NatsService) PublishMessage(ctx context.Context, workflowInstanceID string, name string, key string, vars []byte) error

PublishMessage publishes a workflow message.

func (*NatsService) PublishWorkflowState

func (s *NatsService) PublishWorkflowState(ctx context.Context, stateName string, state *model.WorkflowState, opts ...PublishOpt) error

PublishWorkflowState publishes a SHAR state object to a given subject

func (*NatsService) SaveState added in v1.0.251

func (s *NatsService) SaveState(ctx context.Context, id string, state *model.WorkflowState) error

SaveState saves the task state.

func (*NatsService) SetAbort added in v1.0.251

func (s *NatsService) SetAbort(processor AbortFunc)

SetAbort sets the funcation called when a workflow object aborts.

func (*NatsService) SetCompleteActivity added in v1.0.235

func (s *NatsService) SetCompleteActivity(processor CompleteActivityFunc)

SetCompleteActivity sets the callback which generates complete activity events.

func (*NatsService) SetCompleteActivityProcessor added in v1.0.215

func (s *NatsService) SetCompleteActivityProcessor(processor CompleteActivityProcessorFunc)

SetCompleteActivityProcessor sets the callback fired when an activity completes.

func (*NatsService) SetCompleteJobProcessor

func (s *NatsService) SetCompleteJobProcessor(processor CompleteJobProcessorFunc)

SetCompleteJobProcessor sets the callback for completed tasks.

func (*NatsService) SetEventProcessor

func (s *NatsService) SetEventProcessor(processor EventProcessorFunc)

SetEventProcessor sets the callback for processing workflow activities.

func (*NatsService) SetInFlight added in v1.0.235

func (s *NatsService) SetInFlight(ctx context.Context, wfiID string, activityID string, inFlight bool) error

SetInFlight updates a workflow instance with the currently executing activity.

func (*NatsService) SetLaunchFunc added in v1.0.215

func (s *NatsService) SetLaunchFunc(processor LaunchFunc)

SetLaunchFunc sets the callback used to start child workflows.

func (*NatsService) SetMessageCompleteProcessor

func (s *NatsService) SetMessageCompleteProcessor(processor MessageCompleteProcessorFunc)

SetMessageCompleteProcessor sets the callback for completed messages.

func (*NatsService) SetMessageProcessor added in v1.0.224

func (s *NatsService) SetMessageProcessor(processor MessageProcessorFunc)

SetMessageProcessor sets the callback used to create new workflow instances based on a timer.

func (*NatsService) SetTraversalProvider added in v0.1.181

func (s *NatsService) SetTraversalProvider(provider TraversalFunc)

SetTraversalProvider sets the callback used to handle traversals.

func (*NatsService) Shutdown

func (s *NatsService) Shutdown()

Shutdown signals the engine to stop processing.

func (*NatsService) StartProcessing

func (s *NatsService) StartProcessing(ctx context.Context) error

StartProcessing begins listening to all of the message processing queues.

func (*NatsService) StoreWorkflow

func (s *NatsService) StoreWorkflow(ctx context.Context, wf *model.Workflow) (string, error)

StoreWorkflow stores a workflow definition and returns a unique ID

func (*NatsService) WorkflowStats added in v0.1.134

func (s *NatsService) WorkflowStats() *model.WorkflowStats

WorkflowStats obtains the running counts for the engine

type PublishOpt added in v1.0.215

type PublishOpt interface {
	Apply(n *publishOptions)
}

PublishOpt represents an option that can be used when publishing a workflow state

type TraversalFunc added in v0.1.181

type TraversalFunc func(ctx context.Context, wfi *model.WorkflowInstance, trackingId common.TrackingID, outbound *model.Targets, el map[string]*model.Element, v []byte) error

TraversalFunc is the callback function type used to handle traversals.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL