Packages

trait Workflow[O] extends AnyRef

Workflows must be defined in terms of a particular type of UnitDef they target, and an output of the workflow. By having a workflow specilized to a particular type of unit, we avoid having to have 'uber workflows' that need to handle every possible type of unit, which reduces the implementation complexity of a given workflow quite considerably. In addition, the output type O is intended to provide an opertunity for the workflow to output something more than just effects. For example, a workflow could accumulate a set of logs, or some reporting state - whatever - it doesnt matter.

Workflows define both setup (deploy) and teardown (detroy) workflow

Source
Workflow.scala
Linear Supertypes
Known Subclasses
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Workflow
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Abstract Value Members

  1. abstract def deploy(id: ID, hash: String, unit: @@[UnitDef, Versioned], p: Plan, dc: Datacenter, ns: Namespace): WorkflowF[O]
  2. abstract def destroy(d: Deployment, dc: Datacenter, ns: Namespace): WorkflowF[O]
  3. abstract def name: WorkflowRef