🟢 Operaton ​
Engine-specific behavior when using processEngine = OPERATON.
Operaton is an open-source fork of Camunda 7. It follows the same extraction patterns as Camunda 7, but uses its own XML namespace (http://operaton.org/schema/1.0/bpmn) with the operaton: prefix instead of camunda:.
Migrating from Camunda 7?
If your Operaton models were originally created with Camunda 7 Modeler and still use camunda: namespace attributes, use processEngine = CAMUNDA_7 instead until you migrate the namespace.
Service Task Detection ​
Service tasks are detected via one of these operaton: attributes:
operaton:delegateExpression— e.g.#{sendMailDelegate}operaton:class— e.g.com.example.SendMailDelegateoperaton:topic— for external tasks, e.g.mail.send
<bpmn:serviceTask id="Activity_SendMail" name="Send Mail"
operaton:delegateExpression="#{sendMailDelegate}">
</bpmn:serviceTask>The attribute value becomes the entry in the generated TaskTypes object.
Variable Extraction ​
I/O Mappings ​
Variables are extracted from operaton:inputOutput:
<bpmn:extensionElements>
<operaton:inputOutput>
<operaton:inputParameter name="orderId">${orderId}</operaton:inputParameter>
<operaton:outputParameter name="mailSent">true</operaton:outputParameter>
</operaton:inputOutput>
</bpmn:extensionElements>The name attribute of each parameter becomes a variable.
Message Start Events
operaton:inputOutput is not supported on message start events. Use extension properties with additionalVariables instead (see below).
Additional Variables (Extension Properties) ​
For elements where I/O mappings aren't supported (like message start events), you can declare variables via operaton:properties:
<bpmn:extensionElements>
<operaton:properties>
<operaton:property name="additionalVariables" value="orderId, customerEmail, amount" />
</operaton:properties>
</bpmn:extensionElements>The comma-separated list is parsed and each value becomes a variable. This works on any BPMN element.
Call Activity Mappings ​
Call activity variables come from operaton:in and operaton:out mappings, not from operaton:inputOutput:
<bpmn:callActivity id="CallActivity_Process" calledElement="sub-process">
<bpmn:extensionElements>
<operaton:in source="orderId" target="orderId" />
<operaton:out source="result" target="processResult" />
</bpmn:extensionElements>
</bpmn:callActivity>Variables are extracted from the source attribute of operaton:in and the target attribute of operaton:out.
Multi-Instance ​
Multi-instance variables come from attributes on the multiInstanceLoopCharacteristics element:
<bpmn:multiInstanceLoopCharacteristics
operaton:collection="${subscribers}"
operaton:elementVariable="subscriber" />Extracted variables: subscribers (from collection expression), subscriber (element variable)