Extendable workflow engine for the Moqui Framework.
A Workflow
is a set of activities involved in moving from the beginning to the end of a work process.
Each workflow is linked to a single entity by means of a WorkflowType
.
When the workflow engine is triggered for a specific entity value it creates a new WorkflowInstance
.
You will be carrying out these steps to install the workflow engine.
- Download the Moqui Framework (optional)
- Download the myaddons.xml file
- Download the workflow component
In case you don't have the Moqui Framework yet then you can can download it using this command:
$ git clone https://github.com/moqui/moqui-framework.git
Using wget:
$ cd moqui-framework
$ wget https://raw.githubusercontent.com/netvariant/moqui-workflow/master/myaddons.xml
Using curl:
$ cd moqui-framework
$ curl -O https://raw.githubusercontent.com/netvariant/moqui-workflow/master/myaddons.xml
If neither command is available then download myaddons.xml file manually and copy it to the Moqui Framework root directory.
You're all set to download the workflow component, just run this command and you're done!
$ ./gradlew getComponent -Pcomponent=moqui-workflow
Configuring the workflow engine involves these tasks.
- Define workflow types
- Design a workflow
- Trigger workflow engine
Workflow types are stores in the moqui.workflow.WorkflowType
entity and must be defined before the workflow engine is used.
You can define a new workflow type in your component seed data as follows:
$ <moqui.workflow.WorkflowType typeId="WF_EXAMPLE" typeName="Example Workflow" statusTypeId="ExampleStatus" primaryEntityName="moqui.example.Example" primaryViewEntityName="moqui.example.Example" primaryKeyField="exampleId"/>
The brief explanation of the workflow type fields can be found in the table below:
Field Name | Description |
---|---|
typeId | Type primary key |
typeName | User friendly type name |
statusTypeId | Allowed statuses for this type of workflow |
primaryEntityName | Entity used by the workflow engine for write operations |
primaryViewEntityName | View entity used by the workflow engine for read operations |
primaryKeyField | Entity primary key field name |
To be completed
You can start/stop workflow instances using Moqui services. The workflow engine comes with the following services:
Service Name | Description |
---|---|
moqui.workflow.WorkflowServices.create#WorkflowInstance | Creates a new workflow instance |
moqui.workflow.WorkflowServices.start#WorkflowInstance | Starts an existing workflow instance |
moqui.workflow.WorkflowServices.suspend#WorkflowInstance | Suspends an existing workflow instance |
moqui.workflow.WorkflowServices.resume#WorkflowInstance | Resumed a suspended workflow instance |
moqui.workflow.WorkflowServices.abort#WorkflowInstance | Aborts an active workflow instance |
In a real life scenario you calling the above services using SECA/EECA rules.
This project was build with ❤️ by the good fellas at Netvariant.
This project is licensed under the CC0 License - see the LICENSE.md file for details.