api

package
v0.0.0-...-0f8ae5d Latest Latest
Warning

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

Go to latest
Published: Dec 31, 2019 License: Apache-2.0 Imports: 21 Imported by: 0

Documentation

Index

Constants

View Source
const ErrInvocationCanceled = "workflow invocation was canceled"

Variables

View Source
var (
	DefaultInvocationMonitor = monitor.NewInvocationMonitor()
)

Functions

This section is empty.

Types

type CallConfig

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

type CallOption

type CallOption func(op *CallConfig)

func AwaitWorklow

func AwaitWorklow(timeout time.Duration) CallOption

func PostTransformer

func PostTransformer(fn func(ti *types.TaskInvocation) error) CallOption

func WithContext

func WithContext(ctx context.Context) CallOption
type Consent struct {
	consent.ConsentStore
}

Consent consinst of two components, a consentStore in which consent information is persisted ready to be queried, and an event listener which runs in a goroutine and recieves updates for consent information

func NewConsentAPI

func NewConsentAPI(cs consent.ConsentStore) *Consent

func (*Consent) Query

func (capi *Consent) Query(cid consent.ID) *types.ConsentStatus

func (*Consent) QueryWorkflowConsent

func (capi *Consent) QueryWorkflowConsent(spec *types.WorkflowInvocationSpec) *types.ConsentStatus

Given the workflow paramaters, resolve the inputs and return the consent ConsentStatus of the workflow

func (*Consent) Update

func (capi *Consent) Update(msg *types.ConsentMessage) error

func (*Consent) WatchConsent

func (capi *Consent) WatchConsent()

Listener starts the Consent Listener and returns. Consent Listener will terminate when the provided context invokes the Done() function

type Dynamic

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

Dynamic contains the API functionality for creating dynamic tasks and workflows.

func NewDynamicApi

func NewDynamicApi(wfAPI *Workflow, wfiAPI *Invocation) *Dynamic

NewDynamicApi creates the Dynamic API.

func (*Dynamic) AddDynamicFlow

func (ap *Dynamic) AddDynamicFlow(invocationID string, parentTaskID string, flow controlflow.Flow) error

AddDynamicFlow inserts the flow as a 'dynamic task' into the workflow invocation with id invocationID as the child of the parent task.

type Invocation

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

Invocation contains the API functionality for controlling (workflow) invocations. This includes starting, stopping, and completing invocations.

func NewInvocationAPI

func NewInvocationAPI(esClient fes.Backend, monitor *monitor.InvocationMonitor) *Invocation

NewInvocationAPI creates the Invocation API.

func (*Invocation) AddTask

func (ia *Invocation) AddTask(invocationID string, task *types.Task) error

AddTask provides functionality to add a task to a specific invocation (instead of a workflow). This allows users to modify specific invocations (see dynamic API). The error can be a validate.Err, proto marshall error, or a fes error.

func (*Invocation) Cancel

func (ia *Invocation) Cancel(invocationID string) error

Cancel halts an invocation. This does not guarantee that tasks currently running are halted, but beyond the invocation will not progress any further than those tasks. The state of the invocation will become ABORTED. If the API fails to append the event to the event store, it will return an error.

func (*Invocation) Complete

func (ia *Invocation) Complete(invocationID string, output *typedvalues.TypedValue, outputHeaders *typedvalues.TypedValue) error

Complete forces the completion of an invocation. This function - used by the controller - is the only way to ensure that a workflow invocation turns into the COMPLETED state. If the API fails to append the event to the event store, it will return an error.

func (*Invocation) Evict

func (ia *Invocation) Evict(invocationID string) error

func (*Invocation) Fail

func (ia *Invocation) Fail(invocationID string, errMsg error) error

Fail changes the state of the invocation to FAILED. Optionally you can provide a custom error message to indicate the specific reason for the FAILED state. If the API fails to append the event to the event store, it will return an error.

func (*Invocation) GetMonitor

func (ia *Invocation) GetMonitor() *monitor.InvocationMonitor

func (*Invocation) Invoke

func (ia *Invocation) Invoke(spec *types.WorkflowInvocationSpec, opts ...CallOption) (string, error)

Invoke triggers the start of the invocation using the provided specification. The function either returns the invocationID of the invocation or an error. The error can be a validate.Err, proto marshall error, or a fes error.

func (*Invocation) Schedule

func (ia *Invocation) Schedule(invocationID string) error

type Provenance

type Provenance struct {
	provenance.Store
}

func NewProvenance

func NewProvenance(store provenance.Store) *Provenance

func (Provenance) GenerateProvenance

func (p Provenance) GenerateProvenance(wfi *types.WorkflowInvocation) error

TODO Currently the provenance graph is regenerated for every finished invocation, however, the sometimes only difference is the root node. As an optimisation we could cache workflow provenance DAGs with the workflow ID

type Task

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

Task contains the API functionality for controlling the lifecycle of individual tasks. This includes starting, stopping and completing tasks.

func NewTaskAPI

func NewTaskAPI(runtime map[string]fnenv.Runtime, esClient fes.Backend, api *Dynamic) *Task

NewTaskAPI creates the Task API.

func (*Task) Fail

func (ap *Task) Fail(invocationID string, taskID string, errMsg string) error

Fail forces the failure of a task. This turns the state of a task into FAILED. If the API fails to append the event to the event store, it will return an error.

func (*Task) Invoke

func (ap *Task) Invoke(spec *types.TaskInvocationSpec, opts ...CallOption) (*types.TaskInvocation, error)

Invoke starts the execution of a task, changing the state of the task into RUNNING. Currently it executes the underlying function synchronously and manage the execution until completion.

func (*Task) Prepare

func (ap *Task) Prepare(spec *types.TaskInvocationSpec, expectedAt time.Time, opts ...CallOption) error

type Workflow

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

Workflow contains the API functionality for controlling workflow definitions. This includes creating and parsing workflows.

func NewWorkflowAPI

func NewWorkflowAPI(esClient fes.Backend, resolver fnenv.Resolver) *Workflow

NewWorkflowAPI creates the Workflow API.

func (*Workflow) Create

func (wa *Workflow) Create(workflow *types.WorkflowSpec, opts ...CallOption) (string, error)

Create creates a new workflow based on the provided workflowSpec. The function either returns the id of the workflow or an error. The error can be a validate.Err, proto marshall error, or a fes error. TODO check if id already exists

func (*Workflow) Delete

func (wa *Workflow) Delete(workflowID string) error

Delete marks a workflow as deleted, making it unavailable to any future interactions. This also means that subsequent invocations for this workflow will fail. If the API fails to append the event to the event store, it will return an error.

func (*Workflow) Parse

func (wa *Workflow) Parse(workflow *types.Workflow) (map[string]*types.TaskStatus, error)

Parse processes the workflow to resolve any ambiguity. Currently, this means that all the function references are resolved to function identifiers. For convenience this function returns the new WorkflowStatus. If the API fails to append the event to the event store, it will return an error.

Directories

Path Synopsis
Code generated by hack/codegen-events.py.
Code generated by hack/codegen-events.py.
package store provides typed, centralized access to the event-sourced workflow and invocation models
package store provides typed, centralized access to the event-sourced workflow and invocation models

Jump to

Keyboard shortcuts

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