Reference for the deprecated legacy workflows in Atoti Limits, covering the four-eyes, straight-through, and exception processes, state transition tables, breach email configuration, and upload behavior for in-progress limits
Use this file to discover all available pages before exploring further.
These legacy workflows still exist for backward compatibility and to simplify migration efforts but
will be removed in a future release. Please use the newer workflows in your product. This page exists
only for helping users migrate and will be removed in a future release.
Atoti Limits provides a few workflows out of the box with Activiti. The complete tutorial of Activiti can be found on the Activiti website.This section shows you how to use the out-of-box workflows.You can find the Business Process Modeling Notation (BPMN) files in the limits-starter/src/main/resources/processes folder.
bpmn files are in the XML format, however, we recommend that you install the Activiti Diagram Editor plugin in your IDE, such as Intellij or Eclipse, to edit and read the bpmn files in a nice UI workflow representation.The events that trigger a workflow are:
Limit change: a new limit is created or amended through the UI.
An exception (breach or warning) occurs after the limit evaluation.
You can set up workflows for each of these events.
This workflow requires one approval. By default, one user creates the limit, and another approves it. Alternatively, if the limits.workflow-rules.can-approver-be-same-as-creator property in application.yml is enabled, the creator of the limit can also approve it.
See Section:limit workflow in the application.yml configuration file on configuring the workflow. The workflow names must match the process ID in the bpmn:application.yml:
All serviceTasks need to have the associated Bean defined in the LimitsProcessInstanceWorkflowService.java or a delegate service:Location: limits-activeviam/src/main/java/com/activeviam/limits/workflow/instance
File name: DeleteDelegateService.java
The possible actions in each of the actionable states are:
This workflow doesn’t require an approval. The limit is created in approved state.
See Section:limit in the application.yml configuration file on configuring the workflow. The workflow names must match the process ID in the bpmn:application.yml:
See Section: Limit Workflow in the application.yml configuration file on configuring the workflow. The workflow names must match the process ID in the bpmn:application.yml:
All serviceTasks need to have the associated Bean defined in the java file:
Location: limits-activeviam/src/main/java/com/activeviam/limits/workflow/instance
File name: LimitsProcessInstanceWorkflowService.javaThe following diagram represents the various possible states and actions in the Exception workflow:
See Section: Limit Workflow in the application.yml configuration file on configuring the workflow. The workflow
names must match the process ID in the bpmn:application.yml:
The user tasks are defined via configuration properties. You can customize the user tasks by overriding the
activeviam.apps.workflow-service.workflows.actions.* properties for the workflow with
process-id: incident-review-process. The default configuration is:
Default actions for incident-review-process.bpmn
actions: - task-name: User reviews incident name: Review breach action-input-fields: - label: Is the incident valid? task-variable: incidentIsValid input-type: CHECKBOX required: true - label: Classification task-variable: classification input-type: SELECT options: - Unclassified - Technical Issue - True Breach - New Trade - Late Trade - Market Moved required: true - label: Resolution task-variable: resolution input-type: SELECT options: - No action - Hedge exposure - Reduce position - Keep position - Keep, request increase default-value: No action required: true - label: Comment task-variable: comment input-type: TEXT required: false - label: Attachments task-variable: attachments input-type: ATTACHMENTS required: false - label: Attachment link task-variable: attachmentLink input-type: LINK required: false - task-name: User reviews incident name: Review warning action-input-fields: - label: Comment task-variable: comment input-type: TEXT required: false - label: Attachments task-variable: attachments input-type: ATTACHMENTS required: false - label: Attachment link task-variable: attachmentLink input-type: LINK required: false
The service tasks are defined via Spring beans. You can customize the service tasks by defining your own bean with
type org.activiti.api.process.runtime.connector.Connector and name matching the implementation property of the
service task in the BPMN file. The default service task beans are defined in IncidentReviewConfig.java:
Default service tasks for incident-review-process.bpmn
@Bean@ConditionalOnMissingBean(name = "notifyUsersOfNewIncident")public Connector notifyUsersOfNewIncident() { return integrationContext -> { log.info("A new incident has been created, notifying relevant users."); notificationService.publishNotification( Notification.notificationWithDefaultActionsBuilder() .title("New Incident Created") .description("A new incident has been created and requires your review.") .severity(MEDIUM) .classifiers(List.of("incident")) .userRoles(List.of("ROLE_MANAGERS")) .sourceId(integrationContext.getInBoundVariable(OBJECT_ID_VARIABLE_NAME)) .build()); return integrationContext; };}@Bean@ConditionalOnMissingBean(name = "notifyUsersOfIncidentResolution")public Connector notifyUsersOfIncidentResolution() { return integrationContext -> { log.info("An incident has been resolved, notifying relevant users."); integrationContext.addOutBoundVariable(STATUS_VARIABLE_NAME, REVIEWED.toString()); List<Notification> notifications = notificationService.getNotificationsBySourceId( integrationContext.getInBoundVariable(OBJECT_ID_VARIABLE_NAME)); notifications.forEach( notification -> notificationService.updateNotificationStatus( notification.getId(), "The incident has been reviewed.", OBSOLETE)); return integrationContext; };}
The following diagram represents the various possible states and actions in the Incident Review Process workflow:
When a limit is breached, Atoti Limits notifies the specified users by email. Here’s how to configure the email:In the limit-process-exception.bpmn, you can find the following BreachEmail section and configure the “to”, “from”, and “subject” fields, and the email body.
Breach emails use out-of-the-box functionality from Activiti, which causes a performance decrease in the workflow. To avoid this, disable the breach email by removing the “BreachEmail” element from the bpmn file.
Make sure that the paths to the “Breach Email” go to the “BREACHED” node after the change.
If you’d like to use the default Activiti mail provider, replace the activiti:class="package.to.CustomClass" in the <serviceTask> description
with activiti:type="mail"Note in the service task description the element activiti:class="com.activeviam.limits.workflow.service.instance.activity.impl.TestMailActivityBehavior". This is a way of providing a custom Java delegator to override the default MailActivityBehavior.This is an Activiti feature that can be used to provide extra functionality to your project. For example, to avoid sending emails in a test environment, you can do the following:
public class TestMailActivityBehavior extends MailActivityBehavior { protected static final Logger LOGGER = LoggerFactory.getLogger(TestMailActivityBehavior.class.getSimpleName()); @Override public void execute(DelegateExecution execution) { LOGGER.info("Sending test email for execution: " + execution); leave(execution); }}
When uploading limits in bulk, some limits may already be present in the module and in progress in one of the workflows. Here’s how the state of the affected limit changes when this happens: