Templating
CIB seven supports template engines which are implemented as script engines compatible with JSR-223. As a result, templates can be used everywhere where scripts can be used.
In community distributions of CIB seven, the following template engine is provided out of the box:
The script engine Freemarker wrapper implementation can be found in the camunda-bpmn-platform repository.
The following template engines are provided as optional community extensions:
The script engine wrapper implementations can be found in the camunda-7-template-engines-jsr223 community hub repository.
Install a Template Engine
Install a Template Engine for an Embedded Process Engine
A template engine must be installed in the same way as a script engine. This means that the template engine must be added to the process engine classpath.
When using an embedded process engine, the template engine libraries must be added to the
application deployment. When using the process engine in a maven war
project, the template engine
dependencies must be added as dependencies to the maven pom.xml
file:
The Camunda BOM only contains the officially supported freemarker template engine. For the community-driven template engines, please check the Maven coordinates below.
<dependencies>
<!-- freemarker -->
<dependency>
<groupId>org.camunda.template-engines</groupId>
<artifactId>camunda-template-engines-freemarker</artifactId>
</dependency>
</dependencies>
Here are the Maven coordinates of the community extensions:
<dependencies>
<!-- saxon xquery -->
<dependency>
<groupId>org.camunda.community.template.engine</groupId>
<artifactId>camunda-7-template-engine-xquery</artifactId>
</dependency>
<!-- saxon xslt -->
<dependency>
<groupId>org.camunda.community.template.engine</groupId>
<artifactId>camunda-7-template-engine-xslt</artifactId>
</dependency>
<!-- apache velocity -->
<dependency>
<groupId>org.camunda.community.template.engine</groupId>
<artifactId>camunda-7-template-engine-velocity</artifactId>
</dependency>
</dependencies>
Install a Template Engine for a Shared Process Engine
When using a shared process engine, the template engine must be added to the shared process engine
classpath. The procedure for this depends on the application server. In Apache Tomcat, the
libraries have to be added to the shared lib/
folder.
FreeMarker is pre-installed in the Camunda pre-packaged distribution.
Use a Template Engine
If the template engine library is in the classpath, you can use templates everywhere in the BPMN process where you can use scripts, for example as a script task or inputOutput mapping. The FreeMarker template engine is part of the CIB seven distribution.
Inside the template, all process variables of the BPMN element scope are available. The template can also be loaded from an external resource as described in the script source section.
The following example shows a FreeMarker template, of which the result is saved in the process variable
text
.
<scriptTask id="templateScript" scriptFormat="freemarker" camunda:resultVariable="text">
<script>
Dear ${customer},
thank you for working with Camunda ${version}.
Greetings,
Camunda Developers
</script>
</scriptTask>
In an inputOutput mapping it can be very useful to use an external template to generate the
payload of a camunda:connector
.
<bpmn2:serviceTask id="soapTask" name="Send SOAP request">
<bpmn2:extensionElements>
<camunda:connector>
<camunda:connectorId>soap-http-connector</camunda:connectorId>
<camunda:inputOutput>
<camunda:inputParameter name="soapEnvelope">
<camunda:script scriptFormat="freemarker" resource="soapEnvelope.ftl" />
</camunda:inputParameter>
<!-- ... remaining connector config omitted -->
</camunda:inputOutput>
</camunda:connector>
</bpmn2:extensionElements>
</bpmn2:serviceTask>
Use XSLT as Template Engine
Use XSLT Template Engine with an embedded process engine
When using an embedded process engine, the XSLT template engine library must be added to the
application deployment. When using the process engine in a maven war
project, the template engine
dependency must be added as dependencies to the maven pom.xml
file:
<dependencies>
<!-- XSLT -->
<dependency>
<groupId>org.camunda.community.template.engine</groupId>
<artifactId>camunda-7-template-engine-xslt</artifactId>
</dependency>
</dependencies>
Use XSLT Templates
The following is an example of a BPMN ScriptTask used to execute an XSLT Template:
<bpmn2:scriptTask id="ScriptTask_1" name="convert input"
scriptFormat="xslt"
camunda:resource="org/camunda/bpm/example/xsltexample/example.xsl"
camunda:resultVariable="xmlOutput">
<bpmn2:extensionElements>
<camunda:inputOutput>
<camunda:inputParameter name="camunda_source">${customers}</camunda:inputParameter>
</camunda:inputOutput>
</bpmn2:extensionElements>
</bpmn2:scriptTask>
As shown in the example above, the XSL source file can be referenced using the camunda:resource
attribute. It may be loaded from the classpath or the deployment (database) in the same way as
described for script tasks.
The result of the transformation can be mapped to a variable using the camunda:resultVariable
attribute.
Finally, the input of the transformation must be mapped using the special variable camunda_source
using a <camunda:inputParameter ... />
mapping.
A full example of the XSLT Template Engine in CIB seven can be found in the examples’ repository.