ee.telekom.workflow.api.WorkflowDefinition Maven / Gradle / Ivy
package ee.telekom.workflow.api;
/**
* The workflow engine is built for running long-lived business processes. The execution logic for these business processes (or process parts) is defined via
* workflow definitions. You need to write and deploy a workflow definition for every business process (or multiple definitions, if you want to split the
* process into subprocesses/steps) that you want to run on the workflow engine.
*
* A workflow definition is a plain Java class which implements the WorkflowDefinition interface and uses the WorkflowFactory DSL API to define the process
* execution logic. There is no visual drag and drop process view, there is no BPMN.
*
* In addition to a execution logic description, a workflow definition also has a human readable name and a version number. When a new workflow instance (one
* execution of this business process) is created, it starts with the specified (or latest) version number. This workflow instance will live it's entire life
* on this version number. If you make changes into the workflow definition that don't break the backward compatibility, then you may keep the same version
* number and this workflow instance will start using the new definition after the next deployment. But if you make changes that break the backward
* compatibility, you need to increase the version number, and then the instance won't automatically migrate to the new definition. This also means that you
* must keep the workflow definition previous versions present for as long as there are running instances on these previous versions (when you increase the
* workflow definition version from 1 to 2, you must keep the old java file with version 1 and add a new java file with version 2).
*
* The workflow definitions are meant to be kept in your implementation projects (far away from the engine implementation repository, to provide a clear
* distinction between the platform and the actual workflow business logic code) together with your service layer beans and plugins/event listeners.
* The workflow definitions must be defined as Spring beans in your implementation project's app context (@Component).
*
* The workflow engine converts your definition into internal graph format and stores the result in the internal repository. The engine then provides you
* with different interfaces (web console, REST services, engine facade) to start a new workflow instance and to interact with existing instances.
*
* @author Erko Hansar
* @see WorkflowFactory
*/
public interface WorkflowDefinition{
/**
* Return a human readable name for this workflow definition.
*
* @return a human readable name for this workflow definition
*/
String getName();
/**
* Return a version number for the current workflow definition.
*
* Used when starting a new workflow instance. This workflow instance will live it's entire life on this version number. If you make changes that don't
* break the backward compatibility, then you may keep the same version number and this workflow instance will start using the new definition after the
* next deployment. But if you make changes that break the backward compatibility, you need to increase the version number, and then the instance won't
* automatically migrate to the new definition.
*
* @return a version number for the current workflow definition
*/
int getVersion();
/**
* This method will be called once per run-time when initializing the workflow definitions for the implementing classes.
*
* Use the given factory like this:
*
* public void configureWorkflowDefinition( WorkflowFactory factory ){
* \/* @formatter:off *\/
* factory
* .start()
* .call( 1, "helloWorldService", "sendHelloToCustomer", "${customerId}" )
* .end();
* \/* @formatter:on *\/
* }
*
*
* @param factory factory provides the DSL API for constructing the workflow definition and is later used by the engine to convert the
*/
void configureWorkflowDefinition( WorkflowFactory factory );
/**
* Return keep history boolean value (default value true) for the current workflow definition.
*
* Value false is used for extremely long running workflows when history information in workflow_instances state and history field is growing too large.
* When value is false then work_items with COMPLETED or CANCELLED status will be deleted. For workflow_instances state field only active token
* will be kept in that field. For workflow_instances history field, only last completed, abort or aborted event will be kept in that field.
*
* @return true if workflow should keep history, false if not
*/
default boolean getKeepHistory() {
return true;
}
/**
* Returns archive period length in days for the workflow definition. Defaults to negative value which means archive is kept infinitely.
*
* When workflow instance is fully executed or aborted, it's data is archived. Archived entries are stored for the given period.
* When archive entry duration is over, it gets automatically deleted.
*
* @return archive period length in days for this workflow definition
*/
default int getArchivePeriodLength() {
return -1;
}
}