The jPDL schema is the schema used in the file
processdefinition.xml
in the process archive.
When parsing a jPDL XML document, jBPM will validate your document against the jPDL schema when two conditions are met: first, the schema has to be referenced in the XML document like this
<process-definition xmlns="urn:jbpm.org:jpdl-3.2"> ... </process-definition>
And second, the xerces parser has to be on the classpath.
The jPDL schema can be found in ${jbpm.home}/src/java.jbpm/org/jbpm/jpdl/xml/jpdl-3.2.xsd
or at http://jbpm.org/jpdl-3.2.xsd.
Table 17.1.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | optional | the name of the process |
swimlane | element | [0..*] | the swimlanes used in this process. The swimlanes represent process roles and they are used for task assignments. |
start-state | element | [0..1] | the start state of the process. Note that a process without a start-state is valid, but cannot be executed. |
{end-state|state|node|task-node|process-state|super-state|fork|join|decision} | element | [0..*] | the nodes of the process definition. Note that a process without nodes is valid, but cannot be executed. |
event | element | [0..*] | the process events that serve as a container for actions |
{action|script|create-timer|cancel-timer} | element | [0..*] | global defined actions that can be referenced from events and transitions. Note that these actions must specify a name in order to be referenced. |
task | element | [0..*] | global defined tasks that can be used in e.g. actions. |
exception-handler | element | [0..*] | a list of exception handlers that applies to all exceptions thrown by delegation classes thrown in this process definition. |
Table 17.2.
Name | Type | Multiplicity | Description |
---|---|---|---|
{action|script|create-timer|cancel-timer} | element | 1 | a custom action that represents the behaviour for this node |
common node elements | See common node elements |
Table 17.3.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | required | the name of the node |
async | attribute | { true | false }, false is the default | If set to true, this node will be executed asynchronously. See also Chapter 13, Asynchronous continuations |
transition | element | [0..*] | the leaving transitions. Each transition leaving a node *must* have a distinct name. A maximum of one of the leaving transitions is allowed to have no name. The first transition that is specifed is called the default transition. The default transition is taken when the node is left without specifying a transition. |
event | element | [0..*] | supported event types: {node-enter|node-leave} |
exception-handler | element | [0..*] | a list of exception handlers that applies to all exceptions thrown by delegation classes thrown in this process node. |
timer | element | [0..*] | specifies a timer that monitors the duration of an execution in this node. |
Table 17.4.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | optional | the name of the node |
task | element | [0..1] | the task to start a new instance for this process or to capture the process initiator. See the section called “Swimlane in start task” |
event | element | [0..*] | supported event types: {node-leave} |
transition | element | [0..*] | the leaving transitions. Each transition leaving a node *must* have a distinct name. |
exception-handler | element | [0..*] | a list of exception handlers that applies to all exceptions thrown by delegation classes thrown in this process node. |
Table 17.5.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | required | the name of the end-state |
end-complete-process | attribute | optional | By default end-complete-process is false which means that only the token ending this end-state is ended. If this token was the last child to end, the parent token is ended recursively. If you set this property to true, then the full process instance is ended. |
event | element | [0..*] | supported event types: {node-enter} |
exception-handler | element | [0..*] | a list of exception handlers that applies to all exceptions thrown by delegation classes thrown in this process node. |
Table 17.7.
Name | Type | Multiplicity | Description |
---|---|---|---|
signal | attribute | optional | {unsynchronized|never|first|first-wait|last|last-wait}, default
is last . signal specifies the effect of task completion
on the process execution continuation. |
create-tasks | attribute | optional | {yes|no|true|false}, default is true . can be set
to false when a runtime calculation has to determine which of the tasks have
to be created. in that case, add an action on node-enter ,
create the tasks in the action and set create-tasks to
false . |
end-tasks | attribute | optional | {yes|no|true|false}, default is false . In case
remove-tasks is set to true, on node-leave ,
all the tasks that are still open are ended.
|
task | element | [0..*] | the tasks that should be created when execution arrives in this task node. |
common node elements | See common node elements |
Table 17.8.
Name | Type | Multiplicity | Description |
---|---|---|---|
binding | attribute | optional | Defines the moment a subprocess is resolved. {late|*} defaults to resolving deploytime |
sub-process | element | 1 | the sub process that is associated with this node |
variable | element | [0..*] | specifies how data should be copied from the super process to the sub process at the start and from the sub process to the super process upon completion of the sub process. |
common node elements | See common node elements |
Table 17.9.
Name | Type | Multiplicity | Description |
---|---|---|---|
{end-state|state|node|task-node|process-state|super-state|fork|join|decision} | element | [0..*] | the nodes of the superstate. superstates can be nested. |
common node elements | See common node elements |
Table 17.12.
Name | Type | Multiplicity | Description |
---|---|---|---|
handler | element | either a 'handler' element or conditions on the transitions should be specified | the name of a org.jbpm.jpdl.Def.DecisionHandler implementation |
transition conditions | attribute or element text on the transitions leaving a decision | the leaving transitions. Each leaving transitions of a node can have a condition. The decision will use these conditions to look for the first transition for which the condition evaluates to true. The first transition represents the otherwise branch. So first, all transitions with a condition are evaluated. If one of those evaluate to true, that transition is taken. If no transition with a condition resolves to true, the default transition (=the first one) is taken. See the condition element | |
common node elements | See common node elements |
Table 17.13.
Name | Type | Multiplicity | Description |
---|---|---|---|
type | attribute | required | the event type that is expressed relative to the element on which the event is placed |
{action|script|create-timer|cancel-timer} | element | [0..*] | the list of actions that should be executed on this event |
Table 17.14.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | optional | the name of the transition. Note that each transition leaving a node *must* have a distinct name. |
to | attribute | required | the hierarchical name of the destination node. For more information about hierarchical names, see the section called “Hierarchical names” |
condition | attribute or element text | optional | a guard condition expression. These condition attributes (or child elements) can be used in decision nodes, or to calculate the available transitions on a token at runtime. |
{action|script|create-timer|cancel-timer} | element | [0..*] | the actions to be executed upon taking this transition. Note that the actions of a transition do not need to be put in an event (because there is only one) |
exception-handler | element | [0..*] | a list of exception handlers that applies to all exceptions thrown by delegation classes thrown in this process node. |
Table 17.15.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | optional | the name of the action. When actions are given names, they can be looked up from the process definition. This can be useful for runtime actions and declaring actions only once. |
class | attibute | either, a ref-name or an expression | the fully qualified class name of the class that implements the
org.jbpm.graph.def.ActionHandler interface.
|
ref-name | attibute | either this or class | the name of the referenced action. The content of this action is not processed further if a referenced action is specified. |
expression | attibute | either this, a class or a ref-name | A jPDL expression that resolves to a method. See also the section called “Expressions” |
accept-propagated-events | attribute | optional | {yes|no|true|false}. Default is yes|true. If set to false, the action will only be executed on events that were fired on this action's element. for more information, see the section called “Event propagation” |
config-type | attribute | optional | {field|bean|constructor|configuration-property}. Specifies how the action-object should be constructed and how the content of this element should be used as configuration information for that action-object. |
async | attibute | {true|false} | Default is false, which means that the action is executed in the thread of the execution. If set to true, a message will be sent to the command executor and that component will execute the action asynchonously in a separate transaction. |
{content} | optional | the content of the action can be used as configuration information for your custom action implementations. This allows the creation of reusable delegation classes. For more about delegation configuration, see the section called “Configuration of delegations”. |
Table 17.16.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | optional | the name of the script-action. When actions are given names, they can be looked up from the process definition. This can be useful for runtime actions and declaring actions only once. |
accept-propagated-events | attribute | optional [0..*] | {yes|no|true|false}. Default is yes|true. If set to false, the action will only be executed on events that were fired on this action's element. for more information, see the section called “Event propagation” |
expression | element | [0..1] | the beanshell script. If you don't specify variable elements, you can write the expression as the content of the script element (omitting the expression element tag). |
variable | element | [0..*] | in variable for the script. If no in variables are specified, all the variables of the current token will be loaded into the script evaluation. Use the in variables if you want to limit the number of variables loaded into the script evaluation. |
Table 17.18.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | required | the process variable name |
access | attribute | optional | default is read,write . It is a comma
separated list of access specifiers. The only access specifiers
used so far are read , write
and required . |
mapped-name | attribute | optional | this defaults to the variable name. it specifies a name to which the variable name is mapped. the meaning of the mapped-name is dependent on the context in which this element is used. for a script, this will be the script-variable-name. for a task controller, this will be the label of the task form parameter and for a process-state, this will be the variable name used in the sub-process. |
Table 17.19.
Name | Type | Multiplicity | Description |
---|---|---|---|
expression | attibute | either this or a class | A jPDL expression. The returned result is transformed to a string with the toString() method. The resulting string should match one of the leaving transitions. See also the section called “Expressions”. |
class | attibute | either this or ref-name | the fully qualified class name of the class that implements the
org.jbpm.graph.node.DecisionHandler interface.
|
config-type | attribute | optional | {field|bean|constructor|configuration-property}. Specifies how the action-object should be constructed and how the content of this element should be used as configuration information for that action-object. |
{content} | optional | the content of the handler can be used as configuration information for your custom handler implementations. This allows the creation of reusable delegation classes. For more about delegation configuration, see the section called “Configuration of delegations”. |
Table 17.20.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | optional | the name of the timer. If no name is specified, the name of the enclosing node is taken. Note that every timer should have a unique name. |
duedate | attribute | required | the duration (optionally expressed in business hours) that specifies the time period between the creation of the timer and the execution of the timer. See the section called “Duration” for the syntax. |
repeat | attribute | optional | {duration | 'yes' | 'true'}after a timer has been executed on the duedate, 'repeat' optionally
specifies duration between repeating timer executions until the node is left.
If yes or true is specified, the same duration
as for the due date is taken for the repeat. See the section called “Duration” for the
syntax. |
transition | attribute | optional | a transition-name to be taken when the timer executes, after firing the timer event and executing the action (if any). |
cancel-event | attribute | optional | this attribute is only to be used in timers of tasks. it specifies the
event on which the timer should be cancelled. by default, this is the
task-end event, but it can be set to e.g.
task-assign or task-start .
The cancel-event types can be combined by specifying them in a
comma separated list in the attribute.
|
{action|script|create-timer|cancel-timer} | element | [0..1] | an action that should be executed when this timer fires |
Table 17.21.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | optional | the name of the timer. The name can be used for cancelling the timer with a cancel-timer action. |
duedate | attribute | required | the duration (optionally expressed in business hours) that specifies the the time period between the creation of the timer and the execution of the timer. See the section called “Duration” for the syntax. |
repeat | attribute | optional | {duration | 'yes' | 'true'}after a timer has been executed on the duedate, 'repeat' optionally
specifies duration between repeating timer executions until the node is left.
If yes of true is specified, the same duration
as for the due date is taken for the repeat. See the section called “Duration” for the
syntax. |
transition | attribute | optional | a transition-name to be taken when the timer executes, after firing the the timer event and executing the action (if any). |
Table 17.22.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | optional | the name of the timer to be cancelled. |
Table 17.23.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | optional | the name of the task. Named tasks can be referenced and looked up via the
TaskMgmtDefinition |
blocking | attribute | optional | {yes|no|true|false}, default is false. If blocking is set to true, the node cannot be left when the task is not finished. If set to false (default) a signal on the token is allowed to continue execution and leave the node. The default is set to false, because blocking is normally forced by the user interface. |
signalling | attribute | optional | {yes|no|true|false}, default is true. If signalling is set to false, this task will never have the capability of trigering the continuation of the token. |
duedate | attribute | optional | is a duration expressed in absolute or business hours as explained in Chapter 14, Business calendar |
swimlane | attribute | optional | reference to a swimlane. If a swimlane is specified on a task, the assignment is ignored. |
priority | attribute | optional | one of {highest, high, normal, low, lowest}. alternatively, any integer number can be specified for the priority. FYI: (highest=1, lowest=5) |
assignment | element | optional | describes a delegation that will assign the task to an actor when the task is created. |
event | element | [0..*] | supported event types: {task-create|task-start|task-assign|task-end}. Especially
for the task-assign we have added a non-persisted property
previousActorId to the TaskInstance |
exception-handler | element | [0..*] | a list of exception handlers that applies to all exceptions thrown by delegation classes thrown in this process node. |
timer | element | [0..*] | specifies a timer that monitors the duration of an execution in this task.
special for task timers, the cancel-event can be specified.
by default the cancel-event is task-end ,
but it can be customized to e.g. task-assign or
task-start .
|
controller | element | [0..1] | specifies how the process variables are transformed into task form parameters. the task form paramaters are used by the user interface to render a task form to the user. |
Table 17.24.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | required | the name of the swimlane. Swimlanes can be referenced and looked up via the
TaskMgmtDefinition |
assignment | element | [1..1] | specifies a the assignment of this swimlane. the assignment will be performed when the first task instance is created in this swimlane. |
Table 17.25.
Name | Type | Multiplicity | Description |
---|---|---|---|
expression | attribute | optional | For historical reasons, this attribute expression does not refer to the jPDL expression, but instead, it is an assignment expression for the jBPM identity component. For more information on how to write jBPM identity component expressions, see the section called “Assignment expressions”. Note that this implementation has a dependency on the jbpm identity component. |
actor-id | attribute | optional | An actorId. Can be used in conjunction with pooled-actors. The actor-id
is resolved as an expression. So you can refer to
a fixed actorId like this actor-id="bobthebuilder" . Or you can refer
to a property or method that returns a String like this:
actor-id="myVar.actorId" , which will invoke the getActorId method
on the task instance variable "myVar".
|
pooled-actors | attribute | optional | A comma separated list of actorIds. Can be used in conjunction
with actor-id. A fixed set of pooled actors can be specified like this:
pooled-actors="chicagobulls, pointersisters" . The
pooled-actors will be resolved as an
expression. So you can also refer to a property or method that has to
return, a String[], a Collection or a comma separated list of pooled actors.
|
class | attribute | optional | the fully qualified classname of an implementation of
org.jbpm.taskmgmt.def.AssignmentHandler |
config-type | attribute | optional | {field|bean|constructor|configuration-property}. Specifies how the assignment-handler-object should be constructed and how the content of this element should be used as configuration information for that assignment-handler-object. |
{content} | optional | the content of the assignment-element can be used as configuration information for your AssignmentHandler implementations. This allows the creation of reusable delegation classes. for more about delegation configuration, see the section called “Configuration of delegations”. |
Table 17.26.
Name | Type | Multiplicity | Description |
---|---|---|---|
class | attribute | optional | the fully qualified classname of an implementation of
org.jbpm.taskmgmt.def.TaskControllerHandler |
config-type | attribute | optional | {field|bean|constructor|configuration-property}. Specifies how the assignment-handler-object should be constructed and how the content of this element should be used as configuration information for that assignment-handler-object. |
{content} | either the content of the controller is the configuration of the specified task controller handler (if the class attribute is specified. if no task controller handler is specified, the content must be a list of variable elements. | ||
variable | element | [0..*] | in case no task controller handler is specified by the class attribute, the content of the controller element must be a list of variables. |
Table 17.27.
Name | Type | Multiplicity | Description |
---|---|---|---|
name | attribute | required | the name of the sub process. Can be an EL expression, as long as it resolves to a String. Powerful especially with late binding in the process-state. To know how you can test subprocesses, see the section called “Testing sub processes” |
version | attribute | optional | the version of the sub process. If no version is specified, the latest version of the given process as known while deploying the parent process-state will be taken. |
binding | attribute | optional | indicates if the version of the sub process should be determined
when deploying the parent process-state
(default behavior), or when actually invoking the sub process
(binding="late" ). When both version and
binding="late" are given then jBPM will use the version as
requested, but will not yet try to find the sub process when the parent
process-state is deployed.
|
Table 17.28.
Name | Type | Multiplicity | Description |
---|---|---|---|
{content} For backwards compatibility, the condition can also be entered with the 'expression' attribute, but that attribute is deprecated since 3.2 | required | The contents of the condition element is a
jPDL expression that should evaluate to a boolean. A decision takes the
first transition (as ordered in the processdefinition.xml) for which the expression
resolves to true . If none of the conditions resolve
to true, the default leaving transition (== the first one) will be taken.
|
Table 17.29.
Name | Type | Multiplicity | Description |
---|---|---|---|
exception-class | attribute | optional | specifies the fully qualified name of the java throwable class that should match
this exception handler. If this attribute is not specified, it matches all exceptions
(java.lang.Throwable ). |
action | element | [1..*] | a list of actions to be executed when an exception is being handled by this exception handler. |