Title: BPEL Extensions Category: documentation # Overview ODE extends the [WS-BPEL](/ws-bpel-20.html) in areas that aren't covered by the spec. This page details these extensions. * [Implicit Correlations](#BPELExtensions-ImplicitCorrelations) * [Activity Failure and Recovery](#BPELExtensions-ActivityFailureandRecovery) * [Extension Activities & Extensible Assign Operations](#BPELExtensions-ExtensionActivities-ExtensibleAssignOperations) * [XPath Extensions](#BPELExtensions-XPathExtensions) * [XQuery Extensions](#BPELExtensions-XQueryExtensions) * [External Variables](#BPELExtensions-ExternalVariables) * [Headers Handling](#BPELExtensions-HeadersHandling) * [RESTful BPEL, Part I](#BPELExtensions-RESTfulBPEL-PartI) * [RESTful BPEL, Part II](#BPELExtensions-RESTfulBPEL-PartII) * [Iterable ForEach](#BPELExtensions-IterableForEach) * [Flexible Assigns](#BPELExtensions-FlexibleAssigns) * [Process Contexts](#BPELExtensions-ProcessContexts) ## [Implicit Correlations](implicit-correlations.html) BPEL process instances are stateful — therefore, a client interacting with the BPEL engine must identify the particular instance with which it intends to interact in all of its communications. The BPEL specification defines a mechanism — *correlation* — which allows the process designer to specify which parts of an incoming message (i.e. a message going from a client to the BPEL server) should be used to identify the target process instance. Correlation is a powerful mechanism — however it is a bit complicated and relies on "in-band" message data to associate a messages with a process instance. To keep simple cases simple, ODE provides an alternative correlation mechanism — *implicit correlation* — that automatically handles correlation through "out-of-band" session identifiers. The mechanism is simple: a unique session identifier is associated with every every partner link instance. When a message is sent on a partner link, the session identifier is sent along with the message. The recipient is then able to use the received session identifier in subsequent communications with the process instance. Messages received by the BPEL engine that have a session identifier are routed to the correct instance (and partner link) by that session identifier. [Read more](implicit-correlations.html) ## [Activity Failure and Recovery](activity-failure-and-recovery.html) There are several types of error conditions. In this document we introduce a class of error condition called *failures*, distinct from *faults*, and describe how failures are caught and handled by the process engine. For example, when the process is unable to perform DNS resolution to determine the service endpoint, it generates a failure. An administrator can fix the DNS server and tell the process engine to retry the activity. Had the DNS error been reported as a fault, the process would either terminate or require complex fault handling and recovery logic to proceed past this point of failure. In short, failures shields the process from common, non-terminal error conditions while retaining simple and straightforward process definitions that do not need to account for these error conditions. [Read more](activity-failure-and-recovery.html) ## [Extension Activities & Extensible Assign Operations](extension-activities-extensible-assign-operations.html) Apache ODE provides a plug-in architecture for custom activity implementations and custom variable assignment logic. Such plug-ins can be registered to ODE and can be used according to the WS-BPEL 2.0 extensibility mechnisms (`` & ``). [Read more](extension-activities-extensible-assign-operations.html) ## [XPath Extensions](xpath-extensions.html) Apache ODE extends the default XPath coverage provided by the WS-BPEL specification mostly by adding support for [XPath 2.0](http://www.w3.org/TR/xpath20/) and by offering a few utility extension functions to make some assignments easier. [Read more](xpath-extensions.html) ## [XQuery Extensions](xquery-extensions.html) Apache ODE extends the default XPath coverage provided by the WS-BPEL specification mostly by adding support for [XQuery 1.0](http://www.w3.org/TR/xquery/) and by offering a few utility extension functions to make some assignments easier. [Read more](xquery-extensions.html) ## [External Variables](external-variables.html) External variables are an easy way to share data between the process and external systems, by treating those independent entities as BPEL variables that can be used in expressions and assignments. External variables may be records stored in the database, REST resources, etc. [Read more](external-variables.html) ## [Headers Handling](headers-handling.html) There are several situations where one would want to access headers form the wire format in their BPEL process. It could be to assign them to another message and pass them around or to execute some business logic that's header-dependent (often a bad idea but sometimes there's no choice). ODE supports the manipulation of wire format headers in two different ways. [Read more](headers-handling.html) ## [RESTful BPEL, Part I](restful-bpel-part-i.html) Extends the invoke activity to handle RESTful Web services. This extension uses BPEL variables of type xsd:uri and xsd:string instead of partner links, and does away with the WSDL indirection, making it straightforward to develop processes that use RESTful Web services. [Read more](restful-bpel-part-i.html) ## [RESTful BPEL, Part II](restful-bpel-part-ii.html) Extends receive and onEvent to expose RESTful resources that. This extension adds the ability to declare and instantiate resources, and specific handling for the HTTP methods GET, POST, PUT and DELETE. [Read more](restful-bpel-part-ii.html) ## [Iterable ForEach](iterable-foreach.html) Extends the activity so that the counter variable iterates over the items contained in a given sequence. This extension provides an alternative and more dynamic way of generating M branches, where M is the size of the binding sequence. The semantics of the stays the same, in that the loop is deemed to be complete if B out of the M branches complete (successfully), where B is its actual value. [Read more](iterable-foreach.html) ## [Flexible Assigns](flexible-assigns.html) Extends the activity so that it can be made to either ignore or insert data that is missing in the to-spec of a copy operation. This shortcut allows users to handle what would normally be fault scenarios, in a more graceful and intuitive way. [Read more](flexible-assigns.html) ## [Process Contexts](process-contexts.html) Extends BPEL and ODE to allow the circulation of transport metadata (like security tokens, correlation keys, or tracing informations) from messages to processes and then from processes to messages. [Read more](process-contexts.html)