This section will highlight important requirements or describe any additional cross-cutting requirements that apply to this Building Block.
The cross-cutting requirements described in this section are an extension of the cross-cutting requirements defined in the architecture specification document.
Personal data must be kept private and never shared with any parties, except where specific authorization has been granted.
Logs must be kept in a database of all records that are created, updated, or deleted. Logs must include timestamps and identify the user and affiliation that performed the transaction.
Source code should be available and easily accessible.
The Workflow Building Block application must support communication between multiple instances of the same application (e.g., when deployed in a high-availability environment such as a Kubernetes cluster with a load balancer) so that redundant copies of the workflow engine can guarantee not to duplicate individual activities in an instance or mistakenly create multiple instances of the same process when only one is requested (i.e., the Workflow engine must handle executing instances as “singletons” across a distributed computing environment).
The following standards are applicable to data structures in the Workflow Building Block:
The workflow Building Block should leverage BPMN v2.0.2 - Business Process Model and Notation
Rest APIs should use JSON payloads. Note that we are not using XML.