This chapter includes the following sections:
This section provides an introduction to the BPEL process service component in the design environment.
You add BPEL process service components to SOA composite applications in the .
To add a BPEL process service component:
Follow the instructions in Table 4-1 to start Oracle JDeveloper.
Table 4-1 Starting Oracle JDeveloper
| To Start... | On Windows... | On UNIX... | 
|---|---|---|
| Oracle JDeveloper | 
 | 
 | 
Add a BPEL process service component through one of the following methods:
As a service component in an existing SOA composite application:
From the Components section of the Components window, drag a BPEL Process service component into the . This invokes the Create BPEL Process dialog shown in Figure 4-1.
In a new application:
From the Applications window, select File > New > Application.
Under General in the Categories list, select Applications.
In the Items list, select SOA Application, and click OK.
This starts the Create SOA Application wizard.
In the Application Name dialog, enter an application name in the Application Name field.
In the Directory field, accept the default location or enter a new directory path in which to create the SOA composite application.
Click Next.
In the Project Name dialog, enter a name in the Project Name field.
In the Directory field, accept the default location or enter a new directory path in which to create the project.
Click Next.
In the Start from section, ensure that Standard Composite is selected. The other selection, SOA Template, enables you to create a reusable part of a SOA project to bootstrap new projects. For more information, see Oracle SOA Suite Templates and Reusable Subprocesses .
In the Project SOA Settings dialog, select Composite With BPEL Process.
Click Finish.
This invokes the Create BPEL Process dialog shown in Figure 4-1.
Provide the required details, as described in Table 4-2.
Note:
You cannot use BPEL 1.1 and BPEL 2.0 syntax in the same .bpel file. However, you can include BPEL 1.1 and BPEL 2.0 projects in the same SOA composite application.
Table 4-2 Create BPEL Process Dialog
| Field | Description | 
|---|---|
| BPEL Specification | Select the type of BPEL process to create. 
 | 
| Name | Enter a name for the BPEL process or accept the default name. The name you enter becomes the file name for the BPEL process and Web Services Description Language (WSDL) files in the Applications window. Always use completely unique names when creating BPEL processes. Do not create the following: 
 | 
| Namespace | Use the default namespace path or enter a custom path. | 
| Directory | Specify a directory in which to place BPEL process service component artifacts or accept the default directory of  You can change the directory path, but ensure that the directory is beneath the  | 
| Template | Select a template based on the type of BPEL process service component you want to design. A template provides a basic set of default files in the Applications window ( 
 | 
| Service Name | Accept the default value or enter the name of the service this process is exposing. When you open an invoke, receive, OnMessage, or reply activity, the service name appears by default in the Partner Link field. This name is the same name as the partner link. | 
| Expose as a SOAP Service | Select this check box to create a BPEL process service component that is automatically connected (wired) to an inbound simple object access protocol (SOAP) web service binding component. If you do not select this check box, the BPEL process service component is created as a standalone component in the SOA Composite Editor. You can explicitly associate the BPEL process service component with a service at a later time. This check box is selected by default. | 
| Delivery Note: This field is displayed if you selected one of these templates in the Template list: 
 | Set the persistence policy of the process in the delivery layer. This list enables you to specify a value for the  
 For information about transaction and fault propagation semantics for this property, see Transaction and Fault Propagation Semantics in BPEL Processes. For information about changing the value of this property in the Property Inspector, see How to Define Deployment Descriptor Properties in the Property Inspector. | 
| Transaction Note: This field is displayed if you selected Synchronous BPEL Process in the Template list. | Set the transaction behavior of the BPEL instance for initiating calls. This list enables you to specify a value for the  
 Note: This property does not apply for midprocess receive activities. In those cases, another thread in another transaction is used to process the message. This is because a correlation is needed and it is always done asynchronously. For information about transaction and fault propagation semantics for this property, see Transaction and Fault Propagation Semantics in BPEL Processes. For information about changing the value of this property in the Property Inspector, see How to Define Deployment Descriptor Properties in the Property Inspector. | 
| Input | Accept the default input XSD schema or click the Search icon to select a different XSD. If you click the Search icon, the Type Chooser dialog appears. Browse the imported schemas and select the input element (for example, a purchase order). You can also import an existing schema or WSDL in the Type Chooser dialog. The Type Chooser dialog displays information based on the context of its use. For example, if selecting a simple, message, or element type for a variable, the dialog displays XML schema simple types, WSDL file message types, or XML schema elements, respectively. If selecting a message part type, the dialog displays project schema files, XML schema simple types, and project WSDL files. | 
| Output | Accept the default output XSD schema or click the Search icon to select a different XSD. If you click the Search icon, the Type Chooser dialog appears. Browse the imported schemas and select the output element (for example, a purchase order). | 
Click OK.
Oracle BPEL Designer displays the sections shown in Figure 4-2.
Each section of this view enables you to perform specific design and deployment tasks. Table 4-3 identifies the sections listed in Figure 4-2.
Table 4-3 Oracle JDeveloper Sections
| Element | Description | 
|---|---|
| Applications window (Upper left) | Displays the directories and files of a SOA project. Key directories and files beneath the SOA folder include the following: 
 | 
| Oracle BPEL Designer (Design tab) | Provides a graphical view of the BPEL process service component that you design. This view displays when you perform one of the following actions: 
 As you design the BPEL process service component by dragging activities, creating partner links, and so on, the Design window changes. | 
| Components window (Upper right) | Displays the available activities to add to the BPEL process service component. Activities are the building blocks. The BPEL Constructs, Subprocesses (initially empty), and Oracle Extensions selections of the Components window display a set of activities and subprocesses that you drag into the designer of the BPEL process service component. The Components window displays only those pages relevant to the state of the designer. BPEL Constructs, Subprocesses, and Oracle Extensions are nearly always visible. However, if you are designing a transformation in a transform activity, the Components window only displays selections relevant to that activity, such as String Functions, Mathematical Functions, and Node-set Functions. | 
| Structure window (Lower left) | Provides a structural view of the data in the BPEL process service component currently selected in the designer. You can perform a variety of tasks from this section, including: 
 | 
| Log window (Lower middle) | Displays messages about the status of validation and compilation. To ensure that a BPEL process service component validates correctly, you must ensure that the following information is correct: 
 If deployment is unsuccessful, messages appear that describe the type and location of the error. | 
| Source tab | View the syntax inside the BPEL process service component files. As you drag activities and partner links, and perform other tasks, the syntax in these source files is immediately updated to reflect these changes. | 
| History tab | Displays the revision history of a file and read-only and editable versions of a file side-by-side. | 
| Property Inspector | Displays details about an activity. Single-click an activity in the Design window to open it for editing. For more information, see How to Edit BPEL Activities in the Property Inspector. | 
Note:
To learn more about these sections, you can also place the cursor in the appropriate section and press F1 to display online Help.
Select Information from the Property Structure list above the Oracle BPEL Designer to view the BPEL project version (either 1.1 or 2.0). Figure 4-3 provides details.
The Information dialog is displayed.
You can syntactically and semantically (for example, the partner links or variables are not defined in an invoke activity) validate a BPEL process. If validation fails, information is displayed in the Log window.
To validate a BPEL process service component:
Activities are the building blocks of a BPEL process service component. Oracle BPEL Designer includes a set of activities that you drag into a BPEL process service component. You then double-click an activity to define its attributes (property values). Activities enable you to perform specific tasks within a BPEL process service component. For example, here are several key activities:
An assign activity enables you to manipulate data, such as copying the contents of one variable to another. Figure 4-7 shows an assign activity.
An invoke activity enables you to invoke a service (identified by its partner link) and specify an operation for this service to perform. Figure 4-8 shows an invoke activity.
A receive activity waits for an asynchronous callback response message from a service. Figure 4-9 shows a receive activity. A receive activity is also used when a process is started asynchronously through a partner link.
Figure 4-10 shows an example of a property window (for this example, an invoke activity).
The invoke activity enables you to specify an operation you want to invoke for the service (identified by its partner link). The operation can be one-way or request-response on a port provided by the service. You can also automatically create variables in an invoke activity. An invoke activity invokes a synchronous service or initiates an asynchronous web service.
The invoke activity opens a port in the process to send and receive data. It uses this port to submit required data and receive a response. For synchronous callbacks, only one port is needed for both the send and the receive functions.
For more information about activities, see BPEL Process Activities and Services.
For information about copying and pasting activities in the same project or between projects, see How to Copy and Paste Activities in BPEL Projects .
For information about editing activities in the Property Inspector, see How to Edit BPEL Activities in the Property Inspector.
You can edit the property fields of activities in BPEL 1.1 and 2.0 processes in the Property Inspector of Oracle BPEL Designer in Oracle JDeveloper. This action is the same as double-clicking an activity or right-clicking an activity and selecting Edit, making changes, and clicking Apply or OK.
To edit BPEL activities in the Property Inspector:
You can copy and paste activities in the same BPEL project or between BPEL projects. This prevents you from having to create similar activities from start to finish multiple times. You can design an activity once and use it in multiple places, editing it as necessary.
Note:
You can copy an individual OnAlarm activity from one scope activity and paste it into another scope activity. You can also copy an individual OnAlarm activity from one pick activity and paste it into another pick activity.
Note the following restrictions:
You cannot copy activities from a BPEL 1.1 project to a BPEL 2.0 project or from a BPEL 2.0 project to a BPEL 1.1 project.
In BPEL 2.0 projects, you cannot copy an individual OnAlarm activity from a pick activity into a scope activity, or vice versa. However, this type of copying and pasting is supported in BPEL 1.1 projects.
When you copy and paste a scope activity, the variables referenced in the first scope activity are not copied.
To copy and paste activities:
Right-click the activity to copy.
Select Copy.
Go to the project in which to paste the activity.
Perform one of the following tasks:
Right-click the activity closest to where you want to paste the activity.
Choose to either paste the activity before or after the selected activity.
or
Highlight the BPEL process, as shown in Figure 4-13.
Right-click and select Paste > Paste Into.
The activity is pasted at the top of the BPEL process.
You can add a description of actions to a BPEL process activity. This creates a TODO Tasks icon on the activity. When you place your cursor over this icon, it displays the description of actions. The description can describe the actions performed by the activity in the BPEL process service component.
How to add a description of actions to BPEL process activities:
A partner link enables you to define the external services with which the BPEL process service component is to interact. You can define partner links as services or references (for example, through a JCA adapter) in the (the recommended method) or within a BPEL process service component in Oracle BPEL Designer. Figure 4-15 shows the partner link icon (for this example, named PartnerSupplierMediator).
A partner link type characterizes the conversational relationship between two services by defining the roles played by each service in the conversation and specifying the port type provided by each service to receive messages within the conversation.
Figure 4-16 shows an example of the attributes of a partner link for a service.
Table 4-4 describes the fields of this dialog.
Table 4-4 Create Partner Link Dialog Fields
| Field | Description | 
|---|---|
| Name | A unique and recognizable name you provide for the partner link. | 
| Process | Displays the BPEL process service component name. | 
| WSDL URL | The name and location of the WSDL file or Java interface that you select for the partner link. Click the SOA Service Explorer icon (second icon from the left above the WSDL URL field) to access a window for selecting the WSDL file or Java interface to use. Java interfaces display for selection under the References folder with a name of javaEJB. If the component with which you are wiring this partner link uses WSDL files and you select a Java interface and click OK, a message displays indicating that this component requires a WSDL interface. If you click Yes, a compatible WSDL file is created based on the Java interface. For more information about integrating components that use Java interfaces into SOA composite applications, see Integrating the Spring Framework in SOA Composite Applications. | 
| Partner Link Type | The partner link defined in the WSDL file. | 
| Partner Role | The role performed by the partner link. | 
| My Role | The role performed by the BPEL process service component. If this is a synchronous process case, the BPEL process service component does not have a role. | 
Note:
The Partner Link Type, Partner Role, and My Role fields in the Create Partner Link dialog are defined and required by the BPEL standard.
Best Practice
As a best practice, always create and wire Oracle Mediator and BPEL process service components in the SOA Composite Editor, instead of in Oracle BPEL Designer.
If you add an Oracle Mediator or BPEL process partner link to your BPEL process in Oracle BPEL Designer and connect either partner link to your BPEL process through an invoke activity, the wiring is not automatically reflected above in the SOA Composite Editor. You must explicitly wire the Oracle Mediator or BPEL process service component to your BPEL process again in the SOA Composite Editor.
This is not an issue with human task or business rule partner links in Oracle BPEL Designer; both are also automatically wired in the SOA Composite Editor.
For information about editing partner links in the Property Inspector, see How to Edit BPEL Activities in the Property Inspector.
The method by which you create partner links within the BPEL process in Oracle BPEL Designer impacts how the partner link displays in the . This section describes this impact. The WSDL file can be on the local operating system or hosted remotely (in which case you need a URL for the WSDL).
Likewise, creating and wiring a service or reference binding component to a BPEL process service component in the SOA Composite Editor causes a partner link to display in Oracle BPEL Designer.
To create a partner link:
The following sections describe the impact of partner link creation on the SOA Composite Editor.
Table 4-5 describes the impact on the .
Table 4-5 Impact of Partner Link Creation on the
| Creating the Following for a BPEL Process in Oracle BPEL Designer... | Displays the Following in the ... | 
|---|---|
| A partner link for an outbound adapter | 
 | 
Figure 4-18 shows how this method of creation appears in the .
Table 4-6 describes the impact on the .
Table 4-6 Impact of Partner Link Creation on the
| Creating the Following for a BPEL Process in Oracle BPEL Designer... | Displays the Following in the ... | 
|---|---|
| A partner link for an inbound adapter | 
 | 
Figure 4-19 shows how this method of creation appears in the .
Table 4-7 describes the impact on the .
Table 4-7 Impact of Partner Link Creation on the
| Creating the Following for a BPEL Process in Oracle BPEL Designer... | Displays the Following in the ... | 
|---|---|
| A partner link from an abstract WSDL to call a service | A reference handle with an interface and callback interface defined for the BPEL process service component | 
Table 4-8 describes the impact on the .
Table 4-8 Impact of Partner Link Creation on the
| Creating the Following for a BPEL Process in Oracle BPEL Designer... | Displays the Following in the ... | 
|---|---|
| A partner link is created from an abstract WSDL to implement a service | A service with an interface and callback interface for the BPEL process service component is created. Note: If an external SOAP reference with the specified interface and callback interface exists in the , you can either create a new external SOAP reference and wire to it or wire to the existing external SOAP reference. | 
Figure 4-20 shows how this method of creation appears in the .
Table 4-9 describes the impact on the .
Table 4-9 Impact of Partner Link Creation on the
| Creating the Following for a BPEL Process in Oracle BPEL Designer... | Displays the Following in the ... | 
|---|---|
| A human task or business rule is created | 
 | 
Figure 4-21 shows how this method of creation appears in the .
Table 4-10 describes the impact on the .
Table 4-10 Impact of Partner Link Creation on the
| Creating the Following for a BPEL Process in Oracle BPEL Designer... | Displays the Following in the ... | 
|---|---|
| A partner link by dragging an existing human task, business rule, or mediator service component into the BPEL process | 
 | 
Figure 4-22 shows how this method of creation appears in the .
The Partner Link dialog shown in Figure 4-16 also enables you to take advantage of another key feature that and Oracle JDeveloper provide. Click the Service Wizard icon shown in Figure 4-23 to access the Adapter Configuration wizard.
Adapters enable you to integrate the BPEL process service component (and, therefore, the SOA composite application as a whole) with access to file systems, FTP servers, database tables, database queues, sockets, Java Message Services (JMS), Oracle User Messaging Service, and more. You can also integrate with services such as HTTP binding, direct binding, EJB, and others. This wizard enables you to configure the types of services and adapters shown in Figure 4-24 for use with the BPEL process service component:
For information about the service and adapter types, see Getting Started with Binding Components.
When you select an adapter type (for this example, File was selected in Figure 4-24), the dialog shown in Figure 4-25 prompts you to enter a name. When the wizard completes, a WSDL file by this name appears in the Applications window under the WSDLs folder. The service name must be unique within the project. This file includes the adapter configuration settings you specify with this wizard. Other configuration files (such as header files and files specific to the adapter) are also created and display in the Applications window.
The Adapter Configuration wizard dialogs that appear after the this dialog are based on the adapter type you selected.
You can also add adapters to your SOA composite application as services or references in the .
For more information about technology adapters, see Understanding Technology Adapters.
You can configure BPEL process monitors in Oracle BPEL Designer by selecting Change to Monitor view at the top of Oracle BPEL Designer. Figure 4-26 provides details. BPEL process monitors can send data to Oracle BAM for analysis and graphical display through the Oracle BAM adapter.
For information about business indicators, intervals, and counters, see the Oracle SOA Suite 11g documentation:
http://docs.oracle.com/cd/E28280_01/dev.1111/e10224/bam_adapter.htm#BABIJBCC