1/95
Contents
Title and Copyright Information
Preface
Audience
Documentation Accessibility
Related Documents
Conventions
What's New in This Guide
Part I Introduction to Oracle SOA Suite
1
Introduction to Building Applications with Oracle SOA Suite
1.1
Introduction to Service-Oriented Architecture
1.2
Introduction to Services
1.3
Introduction to Oracle SOA Suite
1.4
Standards Used by Oracle SOA Suite to Enable SOA
1.5
Service Component Architecture within SOA Composite Applications
1.5.1
Service Components
1.5.2
Binding Components
1.5.3
Wires
1.6
Runtime Behavior of a SOA Composite Application
1.6.1
Service Infrastructure
1.6.2
Service Engines
1.6.3
Deployed Service Archives
1.7
Approaches for Designing SOA Composite Applications
1.8
Learning Oracle SOA Suite
1.9
Accessibility Options
1.9.1
How to Enable Accessibility Features in Oracle SOA Composer
1.9.2
How to Enable Accessibility Features in Oracle BPM Worklist
2
Developing SOA Composite Applications with Oracle SOA Suite
2.1
Creating a SOA Application
2.1.1
How to Create a SOA Application and Project
2.1.2
What Happens When You Create a SOA Application and Project
2.2
Adding Service Components
2.2.1
How to Add a Service Component
2.2.2
What You May Need to Know About Adding and Deleting a Service Component
2.2.3
How to Edit a Service Component
2.3
Adding Service Binding Components
2.3.1
How to Add a Service Binding Component
2.3.2
How to Define the Interface (WSDL) for a Web Service
2.3.3
How to View Schemas
2.3.4
How to Edit a Service Binding Component
2.3.5
What You May Need to Know About Adding and Deleting Services
2.3.6
What You May Need to Know About Using the Same Namespace in Different WSDL Files in the Same Composite
2.3.7
What You May Need to Know About WSDL Browsing in the Resource Palette When the SOA Infrastructure Uses Both Internal and External Oracle HTTP Servers
2.4
Adding Reference Binding Components
2.4.1
How to Add a Reference Binding Component
2.4.2
What You May Need to Know About Adding and Deleting References
2.4.3
What You May Need to Know About WSDL References
2.4.4
What You May Need to Know About Mixed Message Types in a WSDL File
2.4.5
What You May Need to Know About Invoking the Default Revision of a Composite
2.5
Adding Wires
2.5.1
How to Wire a Service and a Service Component
2.5.2
How to Wire a Service Component and a Reference
2.5.3
What You May Need to Know About Adding and Deleting Wires
2.6
Adding Security
2.7
Deploying a SOA Composite Application
2.7.1
How to Invoke Deployed SOA Composite Applications
2.8
Managing and Testing a SOA Composite Application
2.8.1
How to Manage Deployed SOA Composite Applications in Oracle JDeveloper
2.8.2
How to Test a Deployed SOA Composite Application
3
Introduction to the SOA Sample Application
3.1
Introduction to the Fusion Order Demo
3.1.1
Store Front Module
3.1.2
WebLogic Fusion Order Demo Application
3.2
Setting Up the Fusion Order Demo Application
3.2.1
Task 1: Install Oracle JDeveloper Studio
3.2.2
Task 2: Install the Fusion Order Demo Application
3.2.3
Task 3: Install Oracle SOA Suite
3.3
Taking a Look at the WebLogic Fusion Order Demo Application
3.3.1
Project Applications of the WebLogic Fusion Order Demo Application
3.3.2
The composite.xml File
3.4
Understanding the OrderBookingComposite Flow
3.5
Deploying Fusion Order Demo
3.5.1
Task 1: Create a Connection to an Oracle WebLogic Server
3.5.2
(Optional) Task 2: Create a Connection to the Oracle BAM Server
3.5.3
Task 3: Install the Schema for the Fusion Order Demo Application
3.5.4
Task 4: Set the Configuration Property for the Store Front Module
3.5.5
Task 5: Edit the Database Connection
3.5.6
Task 6: Deploy the Store Front Module
3.5.7
Task 7: Deploy the WebLogic Fusion Order Demo Application
3.6
Running WebLogic Fusion Order Demo
3.7
Viewing Data Sent to Oracle BAM Server
3.8
Undeploying the Composites for the WebLogic Fusion Order Demo Application
Part II Using the BPEL Process Service Component
4
Getting Started with Oracle BPEL Process Manager
4.1
Introduction to the BPEL Process Service Component
4.1.1
How to Add a BPEL Process Service Component
4.2
Introduction to Activities
4.3
Introduction to Partner Links
4.4
Creating a Partner Link
4.4.1
How to Create a Partner Link
4.4.1.1
Partner Links for an Outbound Adapter
4.4.1.2
Partner Links for an Inbound Adapter
4.4.1.3
Partner Links from an Abstract WSDL to Call a Service
4.4.1.4
Partner Links from an Abstract WSDL to Implement a Service
4.4.1.5
Partner Links and Human Tasks or Business Rules
4.4.1.6
Partner Links from an Existing Human Task, Business Rule, or Oracle Mediator
4.5
Introduction to Adapters
4.6
Introduction to BPEL Process Monitors
5
Introduction to Interaction Patterns in a BPEL Process
5.1
Introduction to One-Way Messages
5.1.1
BPEL Process Service Component as the Client
5.1.2
BPEL Process Service Component as the Service
5.2
Introduction to Synchronous Interactions
5.2.1
BPEL Process Service Component as the Client
5.2.2
BPEL Process Service Component as the Service
5.2.3
Synchronous BPEL Process Invoking an Asynchronous Process
5.3
Introduction to Asynchronous Interactions
5.3.1
BPEL Process Service Component as the Client
5.3.2
BPEL Process Service Component as the Service
5.4
Introduction to Asynchronous Interactions with a Timeout
5.4.1
BPEL Process Service Component as the Client
5.4.2
BPEL Process Service Component as the Service
5.5
Introduction to Asynchronous Interactions with a Notification Timer
5.5.1
BPEL Process Service Component as the Client
5.5.2
BPEL Process Service Component as the Service
5.6
Introduction to One Request, Multiple Responses
5.6.1
BPEL Process Service Component as the Client
5.6.2
BPEL Process Service Component as the Service
5.7
Introduction to One Request, One of Two Possible Responses
5.7.1
BPEL Process Service Component as the Client
5.7.2
BPEL Process Service Component as the Service
5.8
Introduction to One Request, a Mandatory Response, and an Optional Response
5.8.1
BPEL Process Service Component as the Client
5.8.2
BPEL Process Service Component as the Service
5.9
Introduction to Partial Processing
5.9.1
BPEL Process Service Component as the Client
5.9.2
BPEL Process Service Component as the Service
5.10
Introduction to Multiple Application Interactions
6
Manipulating XML Data in a BPEL Process
6.1
Introduction to Manipulating XML Data in BPEL Processes
6.1.1
XML Data in BPEL Processes
6.1.2
Data Manipulation and XPath Standards in Assign Activities
6.2
Delegating XML Data Operations to Data Provider Services
6.2.1
How to Create an Entity Variable
6.2.1.1
Understanding How SDO Works in the Inbound Direction
6.2.1.2
Understanding How SDO Works in the Outbound Direction
6.2.1.3
Creating an Entity Variable and Choosing a Partner Link
6.2.1.4
Creating a Binding Key
6.3
Using Standalone SDO-based Variables
6.3.1
How to Declare SDO-based Variables
6.3.2
How to Convert from XML to SDO
6.4
Initializing a Variable with Expression Constants or Literal XML
6.4.1
How To Assign a Literal XML Element
6.5
Copying Between Variables
6.5.1
How to Copy Between Variables
6.5.2
Initializing Variables with an Inline from-spec in BPEL 2.0
6.6
Accessing Fields in Element and Message Type Variables
6.6.1
How to Access Fields Within Element-Based and Message Type-Based Variables
6.7
Moving and Copying Variables in the Structure Window
6.8
Assigning Numeric Values
6.8.1
How to Assign Numeric Values
6.9
Using Mathematical Calculations with XPath Standards
6.9.1
How To Use Mathematical Calculations with XPath Standards
6.10
Assigning String Literals
6.10.1
How to Assign String Literals
6.11
Concatenating Strings
6.11.1
How to Concatenate Strings
6.12
Assigning Boolean Values
6.12.1
How to Assign Boolean Values
6.13
Assigning a Date or Time
6.13.1
How to Assign a Date or Time
6.14
Manipulating Attributes
6.14.1
How to Manipulate Attributes
6.15
Manipulating XML Data with bpelx Extensions
6.15.1
How to Use bpelx:append
6.15.1.1
bpelx:append in BPEL 1.1
6.15.1.2
bpelx:append in BPEL 2.0
6.15.2
How to Use bpelx:insertBefore
6.15.2.1
bpelx:insertBefore in BPEL 1.1
6.15.2.2
bpelx:insertBefore in BPEL 2.0
6.15.3
How to Use bpelx:insertAfter
6.15.3.1
bpelx:insertAfter in BPEL 1.1
6.15.3.2
bpelx:insertAfter in BPEL 2.0
6.15.4
How to Use bpelx:remove
6.15.4.1
bpelx:remove in BPEL 1.1
6.15.4.2
bpelx:remove in BPEL 2.0
6.15.5
How to Use bpelx:rename and XSD Type Casting
6.15.5.1
bpelx:rename in BPEL 1.1
6.15.5.2
bpelx:rename in BPEL 2.0
6.15.6
How to Use bpelx:copyList
6.15.6.1
bpelx:copyList in BPEL 1.1
6.15.6.2
bpelx:copyList in BPEL 2.0
6.15.7
How to Use Assign Extension Attributes
6.15.7.1
ignoreMissingFromData Attribute
6.15.7.2
insertMissingToData Attribute
6.15.7.3
keepSrcElementName Attribute
6.16
Validating XML Data
6.16.1
How to Validate XML Data in BPEL 1.1
6.16.2
How to Validate XML Data in BPEL 2.0
6.17
Using Element Variables in Message Exchange Activities in BPEL 2.0
6.18
Mapping WSDL Message Parts in BPEL 2.0
6.18.1
How to Map WSDL Message Parts
6.18.2
What Happens When You Map WSDL Message Parts
6.19
Importing Process Definitions in BPEL 2.0
6.20
Manipulating XML Data Sequences That Resemble Arrays
6.20.1
How to Statically Index into an XML Data Sequence That Uses Arrays
6.20.2
How to Use SOAP-Encoded Arrays
6.20.2.1
SOAP-Encoded Arrays in BPEL 2.0
6.20.2.2
Declaring a SOAP Array Using a wsdl:arrayType Attribute Inside a Schema
6.20.3
How to Determine Sequence Size
6.20.4
How to Dynamically Index by Applying a Trailing XPath to an Expression
6.20.4.1
Applying a Trailing XPath to the Result of getVariableData
6.20.4.2
Using the bpelx:append Extension to Append New Items to a Sequence
6.20.4.3
Merging Data Sequences
6.20.4.4
Generating Functionality Equivalent to an Array of an Empty Element
6.20.5
What You May Need to Know About Using the Array Identifier
6.21
Converting from a String to an XML Element
6.21.1
How To Convert from a String to an XML Element
6.22
Understanding Document-Style and RPC-Style WSDL Differences
6.22.1
How To Use RPC-Style Files
6.23
Manipulating SOAP Headers in BPEL
6.23.1
How to Receive SOAP Headers in BPEL
6.23.2
How to Send SOAP Headers in BPEL
6.24
Declaring Extension Namespaces in BPEL 2.0
6.24.1
How to Declare Extension Namespaces
6.24.2
What Happens When You Create an Extension
7
Invoking a Synchronous Web Service from a BPEL Process
7.1
Introduction to Invoking a Synchronous Web Service
7.2
Invoking a Synchronous Web Service
7.2.1
How to Invoke a Synchronous Web Service
7.2.2
What Happens When You Invoke a Synchronous Web Service
7.2.2.1
Partner Link in the BPEL Code
7.2.2.2
Partner Link Type and Port Type in the BPEL Code
7.2.2.3
Invoke Activity for Performing a Request
7.2.2.4
Synchronous Invocation in BPEL Code
7.3
Specifying Transaction Timeout Values in Durable Synchronous Processes
7.3.1
How To Specify Transaction Timeout Values
7.3.2
What You May Need to Know About SyncMaxWaitTime and Durable Synchronous Requests Not Timing Out
7.4
Calling a One-Way Mediator with a Synchronous BPEL Process
8
Invoking an Asynchronous Web Service from a BPEL Process
8.1
Introduction to Invoking an Asynchronous Web Service
8.2
Invoking an Asynchronous Web Service
8.2.1
How to Invoke an Asynchronous Web Service
8.2.1.1
Adding a Partner Link for an Asynchronous Service
8.2.1.2
Adding an Invoke Activity
8.2.1.3
Adding a Receive Activity
8.2.1.4
Performing Additional Activities
8.2.2
What Happens When You Invoke an Asynchronous Web Service
8.2.2.1
portType Section of the WSDL File
8.2.2.2
partnerLinkType Section of the WSDL File
8.2.2.3
Partner Links Section in the BPEL File
8.2.2.4
Composite Application File
8.2.2.5
Invoke and Receive Activities
8.2.2.6
createInstance Attribute for Starting a New Instance
8.2.2.7
Dehydration Points for Maintaining Long-Running Asynchronous Processes
8.2.2.8
Multiple Runtime Endpoint Locations
8.2.3
What You May Need to Know About Midprocess Receive Activities Consuming Messages After Timing Out
8.2.4
What You May Need to Know About Multiple Client Components Invoking a Composite
8.2.5
What You May Need to Know About Limitations on BPEL 2.0 IMA Support
8.2.6
What Happens When You Specify a Conversation ID
8.2.6.1
bpelx:conversationId in BPEL 1.1
8.2.6.2
bpelx:conversationId in BPEL 2.0
8.3
Routing Callback Messages to the Correct Endpoint when Multiple Receive or Pick Activities Use the Same Partner Link
8.3.1
How to Route Callback Messages to the Correct Endpoint when Multiple Receive and Pick Activities Use the Same Partner Link
8.4
Managing Idempotence at the Partner Link Operation Level
8.4.1
How to Manage Idempotence at the Partner Link Operation Level
8.5
Creating a Dynamic Partner Link at Design Time for Use at Runtime
8.5.1
How To Create a Dynamic Partner Link at Design Time for Use at Runtime
8.6
Overriding Security Certificates when Invoking Dynamic Partner Links
8.7
Overriding WSDL Files of Dynamic Partner Links
8.8
Using WS-Addressing in an Asynchronous Service
8.8.1
How to Use WS-Addressing in an Asynchronous Service
8.8.1.1
Using TCP Tunneling to View Messages Exchanged Between Programs
9
Using Correlation Sets and Message Aggregation
9.1
Using Correlation Sets in an Asynchronous Service
9.1.1
How to Use Correlation Sets in an Asynchronous Service
9.1.1.1
Step 1: Creating a Project
9.1.1.2
Step 2: Configuring Partner Links and File Adapter Services
9.1.1.3
Step 3: Creating Three Receive Activities
9.1.1.4
Step 4: Creating Correlation Sets
9.1.1.5
Step 5: Associating Correlation Sets with Receive Activities
9.1.1.6
Step 6: Creating Property Aliases
9.1.1.7
Step 7: Reviewing WSDL File Content
9.1.2
What You May Need to Know About Conversion IDs and Different Composite Revisions
9.1.3
What You May Need to Know About Setting Correlations for an IMA Using a fromParts Element With Multiple Parts
9.2
Routing Messages to the Same Instance
9.2.1
How to Configure BPEL Process Instance Creation
9.2.2
How to Use the Same Operation in Entry and Midprocess Receive Activities
9.2.3
How to Route a Message to a New or Existing Instance when Using Correlation Sets
10
Using Parallel Flow in a BPEL Process
10.1
Introduction to Parallel Flows in BPEL Processes
10.1.1
What You May Need to Know About the Execution of Parallel Flow Branches in a Single Thread
10.2
Creating a Parallel Flow
10.2.1
How to Create a Parallel Flow
10.2.2
What Happens When You Create a Parallel Flow
10.2.3
Synchronizing the Execution of Activities in a Flow Activity
10.2.4
How to Create Synchronization Between Activities Within a Flow Activity
10.2.5
What Happens When You Create Synchronization Between Activities Within a Flow Activity
10.2.6
What You May Need to Know About Join Conditions in Target Activities
10.3
Customizing the Number of Parallel Branches
10.3.1
Customizing the Number of Flow Activities with the flowN Activity in BPEL 1.1
10.3.1.1
How to Create a flowN Activity
10.3.1.2
What Happens When You Create a FlowN Activity
10.3.2
Processing Multiple Sets of Activities with the forEach Activity in BPEL 2.0
10.3.2.1
How to Create a forEach Activity
10.3.2.2
What Happens When You Create a forEach Activity
11
Using Conditional Branching in a BPEL Process
11.1
Introduction to Conditional Branching
11.2
Defining Conditional Branching with the Switch or If Activity
11.2.1
Defining Conditional Branching with the Switch Activity in BPEL 1.1
11.2.1.1
How to Create a Switch Activity
11.2.1.2
What Happens When You Create a Switch Activity
11.2.2
Defining Conditional Branching with the If Activity in BPEL 2.0
11.2.2.1
How to Create an If Activity
11.2.2.2
What Happens When You Create an If Activity
11.3
Defining Conditional Branching with the While Activity
11.3.1
How To Create a While Activity
11.3.2
What Happens When You Create a While Activity
11.4
Defining Conditional Branching with the repeatUntil Activity
11.4.1
How to Create a repeatUntil Activity
11.4.2
What Happens When You Create a repeatUntil Activity
11.5
Specifying XPath Expressions to Bypass Activity Execution
11.5.1
How to Specify XPath Expressions to Bypass Activity Execution
11.5.2
What Happens When You Specify XPath Expressions to Bypass Activity Execution
12
Using Fault Handling in a BPEL Process
12.1
Introduction to a Fault Handler
12.2
Introduction to BPEL Standard Faults
12.2.1
BPEL 1.1 Standard Faults
12.2.2
BPEL 2.0 Standard Faults
12.2.2.1
Fault Handling Order of Precedence in BPEL 2.0
12.3
Introduction to the Business and Runtime Fault Categories of BPEL Faults
12.3.1
Business Faults
12.3.2
Runtime Faults
12.3.2.1
bindingFault
12.3.2.2
remoteFault
12.3.2.3
replayFault
12.3.3
How to Add and Propagate Fault Handling in a Synchronous BPEL Process
12.3.3.1
Edit the Schema and WSDL Files
12.3.3.2
Add a Fault Handler
12.3.3.3
Create a Fault Response Variable
12.3.3.4
Add an Assign Activity to the Catch Activity Branch
12.3.3.5
Add a Reply Activity to the Catch Activity Branch
12.4
Handling Faults with the Fault Management Framework
12.4.1
How to Design a Fault Policy
12.4.1.1
Understanding How Fault Policy Binding Resolution Works
12.4.1.2
Creating a Fault Policy File for Automated Fault Recovery
12.4.1.3
Associating a Fault Policy with Fault Policy Binding
12.4.1.4
Additional Fault Policy and Fault Policy Binding File Samples
12.4.1.5
Designing a Fault Policy with Multiple Rejection Handlers
12.4.2
How to Execute a Fault Policy
12.4.3
How to Use a Java Action Fault Policy
12.4.4
How to Design Fault Policies for Oracle BPM Suite
12.4.5
What You May Need to Know About Fault Management Behavior When the Number of Instance Retries is Exceeded
12.4.6
What You May Need to Know About Executing the Retry Action with Multiple Faults in the Same Flow
12.4.7
What You May Need to Know About Binding Level Retry Execution Within Fault Policy Retries
12.4.8
What You May Need to Know About Defining the ora-java Option
12.5
Catching BPEL Runtime Faults
12.5.1
How to Catch BPEL Runtime Faults
12.6
Getting Fault Details with the getFaultAsString XPath Extension Function
12.6.1
How to Get Fault Details with the getFaultAsString XPath Extension Function
12.7
Throwing Internal Faults with the Throw Activity
12.7.1
How to Create a Throw Activity
12.7.2
What Happens When You Create a Throw Activity
12.7.3
How to Roll Back Activities with a bpelx:rollback Extension in a Throw Activity
12.8
Rethrowing Faults with the Rethrow Activity
12.8.1
How to Create a Rethrow Activity
12.8.2
What Happens When You Rethrow Faults
12.9
Returning External Faults
12.9.1
How to Return a Fault in a Synchronous Interaction
12.9.2
How to Return a Fault in an Asynchronous Interaction
12.10
Using a Scope Activity to Manage a Group of Activities
12.10.1
How to Create a Scope Activity
12.10.2
How to Add Descriptive Notes and Images to a Scope Activity
12.10.3
What Happens After You Create a Scope Activity
12.10.4
What You May Need to Know About Scopes
12.10.5
How to Use a Fault Handler Within a Scope
12.10.6
What You May Need to Know About the idempotent Property and Fault Handling
12.10.7
How to Create a Catch Activity in a Scope
12.10.8
What Happens When You Create a Catch Activity in a Scope
12.10.9
How to Create an Empty Activity to Insert No-Op Instructions into a Business Process
12.10.10
What Happens When You Create an Empty Activity
12.11
Re-executing Activities in a Scope Activity with the Replay Activity
12.11.1
How to Create a Replay Activity
12.11.2
What Happens When You Create a Replay Activity
12.12
Using Compensation After Undoing a Series of Operations
12.12.1
Using a Compensate Activity
12.12.2
How to Create a Compensate Activity
12.12.3
What Happens When You Create a compensate Activity
12.12.4
Using a compensateScope Activity in BPEL 2.0
12.12.5
How to Create a compensateScope Activity
12.12.6
What Happens When You Create a compensateScope Activity
12.13
Stopping a Business Process Instance with a Terminate or Exit Activity
12.13.1
Stopping a Business Process Instance with the Terminate Activity in BPEL 1.1
12.13.1.1
How to Create a Terminate Activity
12.13.1.2
What Happens When You Create a Terminate Activity
12.13.2
Immediately Ending a Business Process Instance with the Exit Activity in BPEL 2.0
12.13.2.1
How to Create an Exit Activity
12.13.2.2
What Happens When You Create an Exit Activity
12.14
Throwing Faults with Assertion Conditions
12.14.1
Introducing Assertion Conditions
12.14.1.1
bpelx:postAssert and bpelx:preAssert Extensions
12.14.1.2
Use of faultName and message Attributes
12.14.1.3
Multiple Assertions
12.14.1.4
Use of Built-in and Custom XPath Functions and $variable References
12.14.1.5
Assertion Condition Evaluation Logging of Events to the Instance Audit Trail
12.14.1.6
Expressions Not Evaluating to an XML Schema Boolean Type Throw a Fault
12.14.1.7
Assertion Conditions in a Standalone Assert Activity
12.14.2
How to Create Assertion Conditions
12.14.3
How to Disable Assertions
12.14.4
What Happens When You Create Assertion Conditions
13
Transaction and Fault Propagation Semantics in BPEL Processes
13.1
Introduction to Transaction Semantics
13.1.1
Oracle BPEL Process Manager Transaction Semantics
13.1.1.1
BPELCaller Process Calls a BPELCallee Process That Has bpel.config.transaction Set to requiresNew
13.1.1.2
BPELCaller Process Calls a BPELCallee Process That Has bpel.config.transaction Set to required
13.2
Introduction to Execution of One-way Invocations
14
Incorporating Java and Java EE Code in a BPEL Process
14.1
Introduction to Java and Java EE Code in BPEL Processes
14.2
Incorporating Java and Java EE Code in BPEL Processes
14.2.1
How to Wrap Java Code as a SOAP Service
14.2.2
What You May Need to Know About Wrapping Java Code as a SOAP Service
14.2.3
How to Embed Java Code Snippets into a BPEL Process with the bpelx:exec Tag
14.2.4
How to Embed Java Code Snippets in a BPEL 2.0 Process
14.2.5
How to Use an XML Facade to Simplify DOM Manipulation
14.2.6
How to Use bpelx:exec Built-in Methods
14.2.7
How to Use Java Code Wrapped in a Service Interface
14.3
Adding Custom Classes and JAR Files
14.3.1
How to Add Custom Classes and JAR Files
14.4
Using Java Embedding in a BPEL Process in Oracle JDeveloper
14.4.1
How To Use Java Embedding in a BPEL Process in Oracle JDeveloper
14.4.2
What You May Need to Know About Using thread.sleep() in a Java Embedding Activity
14.5
Embedding Service Data Objects with bpelx:exec
14.6
Sharing a Custom Implementation of a Class with Oracle BPEL Process Manager
14.6.1
How to Configure the BPEL Connection Manager Class to Take Precedence
15
Using Events and Timeouts in BPEL Processes
15.1
Introduction to Event and Timeout Concepts
15.2
Creating a Pick Activity to Select Between Continuing a Process or Waiting
15.2.1
How To Create a Pick Activity
15.2.2
What Happens When You Create a Pick Activity
15.2.3
What You May Need to Know About Simultaneous onMessage Branches in BPEL 2.0
15.3
Setting Timeouts for Request-Reply and In-Only Operations in Receive Activities
15.3.1
Introducing Timeouts for Request-Reply and In-Only Operations
15.3.1.1
Timeout Settings Relative from When the Activity is Invoked
15.3.1.2
Timeout Settings as an Absolute Date Time
15.3.1.3
Timeout Settings Computed Dynamically with an XPath Expression
15.3.1.4
bpelx:timeout Fault Thrown During an Activity Timeout
15.3.1.5
Event Added to the BPEL Instance Audit Trail During an Activity Timeout
15.3.1.6
Recoverable Timeout Activities During a Server Restart (Refresh Expiration Alarm Table)
15.3.2
How to Set Timeouts in Receive Activities
15.3.3
What Happens When You Set Timeouts in Receive Activities
15.4
Creating a Wait Activity to Set an Expiration Time
15.4.1
How To Specify the Minimum Wait Time
15.4.2
How to Create a Wait Activity
15.4.3
What Happens When You Create a Wait Activity
15.5
Specifying Events to Wait for Message Arrival with an OnEvent Branch in BPEL 2.0
15.5.1
How to Create an onEvent Branch in a Scope Activity
15.5.2
What Happens When You Create an OnEvent Branch
15.6
Setting Timeouts for Durable Synchronous Processes
16
Coordinating Master and Detail Processes
16.1
Introduction to Master and Detail Process Coordinations
16.1.1
BPEL File Definition for the Master Process
16.1.1.1
Correlating a Master Process with Multiple Detail Processes
16.1.2
BPEL File Definition for Detail Processes
16.2
Defining Master and Detail Process Coordination in Oracle JDeveloper
16.2.1
How to Create a Master Process
16.2.2
How to Create a Detail Process
16.2.3
How to Create an Invoke Activity
17
Using the Notification Service
17.1
Introduction to the Notification Service
17.2
Introduction to Notification Channel Setup
17.3
Selecting Notification Channels During BPEL Process Design
17.3.1
How To Configure the Email Notification Channel
17.3.1.1
Setting Email Attachments
17.3.1.2
Formatting the Body of an Email Message as HTML
17.3.1.3
Using Dynamic HTML for Message Content Requires a CDATA Function
17.3.2
How to Configure the IM Notification Channel
17.3.3
How to Configure the SMS Notification Channel
17.3.4
How to Configure the Voice Notification Channel
17.3.5
How to Select Email Addresses and Telephone Numbers Dynamically
17.3.6
How to Select Notification Recipients by Browsing the User Directory
17.4
Allowing the End User to Select Notification Channels
17.4.1
How to Allow the End User to Select Notification Channels
17.4.1.1
How to Create and Send Headers for Notifications
18
Using Oracle BPEL Process Manager Sensors
18.1
Introduction to Oracle BPEL Process Manager Sensors
18.2
Configuring Sensors and Sensor Actions in Oracle JDeveloper
18.2.1
How to Access Sensors and Sensor Actions
18.2.2
How to Configure Activity, Variable, and Fault Sensors
18.2.3
How to Configure Sensor Actions
18.2.4
How to Publish to Remote Topics and Queues
18.2.5
How to Create a Custom Data Publisher
18.2.6
How to Register the Sensors and Sensor Actions in composite.xml
18.3
Viewing Sensors and Sensor Action Definitions in Oracle Enterprise Manager Fusion Middleware Control
Part III Using the Oracle Mediator Service Component
19
Getting Started with Oracle Mediator
19.1
Introduction to Oracle Mediator
19.2
Mediator Functionality
19.2.1
Content-Based and Header-Based Routing
19.2.2
Synchronous and Asynchronous Interactions
19.2.3
Sequential and Parallel Routing of Messages
19.2.4
Message Resequencing
19.2.5
Data Transformation
19.2.6
Payload Validation
19.2.7
Java Callouts
19.2.8
Event Handling
19.2.9
Dynamic Routing
19.2.10
Error Handling
19.2.11
Sending Messages Back to the Caller (Echo)
19.2.12
Multiple Part Messages
19.3
Introduction to the Mediator Editor Environment
19.4
Creating a Mediator
19.4.1
How to Create a Mediator
19.5
Configuring the Mediator Interface Definition
19.5.1
How to Configure the Mediator Interface Definition
19.5.2
What Happens When You Create a Mediator
19.5.2.1
Without an Interface Definition
19.5.2.2
With a WSDL-Based Interface
19.5.2.3
With a One-Way Interface Definition
19.5.2.4
With a Synchronous Interface Definition
19.5.2.5
With an Asynchronous Interface Definition
19.5.2.6
With an Event Subscription
19.6
Defining an Interface for a Mediator
19.6.1
How to Define an Interface for a Mediator
19.7
Generating a WSDL File
19.7.1
How to Generate a WSDL File
19.8
Specifying Validation and Priority Properties
19.9
Modifying a Mediator Service Component
19.9.1
How To Modify Mediator Operations
19.9.2
How To Modify Mediator Event Subscriptions
20
Creating Oracle Mediator Routing Rules
20.1
Introduction to Routing Rules
20.1.1
Static Routing Rules
20.1.1.1
Types of Static Rules
20.1.1.2
Static Routing Rule Components
20.1.2
Dynamic Routing Rules
20.1.3
Sequential and Parallel Execution
20.1.3.1
Basic Principles of Sequential Routing Rules
20.1.3.2
Basic Principles of Parallel Routing Rules
20.2
Resequencing Rules
20.3
Defining Routing Rules
20.3.1
How To Access the Routing Rules Section
20.3.2
How to Create Static Routing Rules
20.3.2.1
How to Specify Mediator Services or Events
20.3.2.2
What You May Need to Know About Echoing a Service
20.3.2.3
How to Specify Sequential or Parallel Execution
20.3.2.4
How to Configure Response Messages
20.3.2.5
How to Handle Premature Callbacks
20.3.2.6
How to Handle Multiple Callbacks
20.3.2.7
How to Handle Faults
20.3.2.8
How to Specify an Expression for Filtering Messages
20.3.2.9
How to Create Transformations
20.3.2.10
How to Assign Values
20.3.2.11
What You May Need to Know About the Assign Activity
20.3.2.12
How to Access Headers for Filters and Assignments
20.3.2.13
How to Use Semantic Validation
20.3.2.14
How to Work with Attachments
20.3.2.15
How to Use Java Callouts
20.3.3
How to Create Dynamic Routing Rules
20.3.4
What You May Need to Know About Using Dynamic Routing Rules
20.3.5
How to Define Default Routing Rules
20.3.5.1
Default Rule Scenarios
20.3.5.2
Default Rule Target
20.3.5.3
Default Rule: Validation, Transformation, and Assign Functionality
20.3.5.4
Default Rule: Java Callouts
20.3.5.5
Default Rule: Mediator .mplan File
20.4
Mediator Routing Use Cases
21
Working with Multiple Part Messages in Oracle Mediator
21.1
Introduction to Mediator Multipart Message Support
21.2
Working with Multipart Request Messages
21.2.1
How to Specify Filter Expressions for Multipart Request Messages
21.2.2
How to Add Validations for Multipart Request Messages
21.2.3
How to Create Transformations for Multipart Request Messages
21.2.4
How to Assign Values for Multipart Request Messages
21.2.5
How to Work with Multipart Reply, Fault, and Callback Source Messages
21.2.6
How to Work with Multipart Target Messages
22
Using Oracle Mediator Error Handling
22.1
Introduction to Mediator Error Handling
22.1.1
Fault Policies
22.1.1.1
Conditions
22.1.1.2
Actions
22.1.2
Fault Bindings
22.1.3
Error Groups in Mediator
22.2
Using Error Handling with Mediator
22.2.1
How to Use Error Handling for a Mediator Service Component
22.2.2
What Happens at Runtime
22.3
Fault Recovery Using Oracle Enterprise Manager Fusion Middleware Control
22.4
Error Handling XML Schema Definition Files
22.4.1
Schema Definition File for fault-policies.xml
22.4.2
Schema Definition File for fault-bindings.xml
23
Resequencing in Oracle Mediator
23.1
Introduction to the Resequencer
23.1.1
Groups and Sequence IDs
23.1.2
Identification of Groups and Sequence IDs
23.2
Resequencing Order
23.2.1
Standard Resequencer
23.2.1.1
Overview of the Standard Resequencer
23.2.1.2
Information Required for Standard Resequencing
23.2.1.3
Example of the Standard Resequencer
23.2.2
FIFO Resequencer
23.2.2.1
Overview of the FIFO Resequencer
23.2.2.2
Information Required for FIFO Resequencing
23.2.2.3
Example of the FIFO Resequencer
23.2.3
Best Effort Resequencer
23.2.3.1
Overview of the Best Effort Resequencer
23.2.3.2
Best Effort Resequencer Message Selection Strategies
23.2.3.3
Best Effort Resequencer Message Delivery
23.2.3.4
Information Required for Best Effort Resequencing
23.2.3.5
Example of Best Effort Resequencing Based on Maximum Rows
23.2.3.6
Example of Best Effort Resequencing Based on a Time Window
23.3
Configuring the Resequencer
23.3.1
How to Specify the Resequencing Level
23.3.2
How to Configure the Resequencing Strategy
24
Understanding Message Exchange Patterns of an Oracle Mediator
24.1
One-way Message Exchange Patterns
24.1.1
The one.way.returns.fault Property
24.2
Request-Reply Message Exchange Patterns
24.3
Request-Reply-Fault Message Exchange Patterns
24.4
Request-Callback Message Exchange Patterns
24.5
Request-Reply-Callback Message Exchange Patterns
24.6
Request-Reply-Fault-Callback Message Exchange Patterns
Part IV Using the Business Rules Service Component
25
Getting Started with Oracle Business Rules
25.1
Introduction to the Business Rule Service Component
25.1.1
Integrating BPEL Processes, Business Rules, and Human Tasks
25.2
Overview of Rules Designer Editor Environment
25.2.1
Application Navigator
25.2.2
Rules Designer Window
25.2.3
Structure Window
25.2.4
Business Rule Validation Log Window
25.3
Introduction to Creating and Editing Business Rules
25.3.1
How to Create Business Rules Components
25.3.2
Introduction to Working with Business Rules in Rules Designer
25.4
Adding Business Rules to a BPEL Process
25.4.1
How to Add Business Rules to a BPEL Process
25.4.2
What Happens When You Add Business Rules to a BPEL Process
25.4.3
What Happens When You Create a Business Rules Dictionary
25.4.4
What You May Need to Know About Invoking Business Rules in a BPEL Process
25.4.5
What You May Need to Know About Decision Component Stateful Operation
25.5
Adding Business Rules to a SOA Composite Application
25.5.1
How to Add Business Rules to a SOA Composite Application
25.5.2
How to Select and Modify a Decision Function in a Business Rule Component
25.6
Running Business Rules in a Composite Application
25.6.1
What You May Need to Know About Testing a Standalone Decision Service Component
25.7
Using Business Rules with Oracle ADF Business Components Fact Types
26
Using Declarative Components and Task Flows
26.1
Introduction to Declarative Components and Task Flows
26.2
Using the Oracle Business Rules Editor Declarative Component
26.2.1
Introduction to the Oracle Business Rules Editor Component
26.2.2
How to Create and Run a Sample Application by Using the Rules Editor Component
26.2.3
How to Deploy a Rules Editor Application to a Standalone Oracle WebLogic Server
26.2.4
What You May Need to Know About the Custom Permissions for the Rules Editor Component
26.2.5
What You May Need to Know About the Supported Tags of the Rules Editor Component
26.3
Using the Oracle Business Rules Dictionary Editor Declarative Component
26.3.1
Introduction to the Oracle Business Rules Dictionary Component
26.3.2
How to Create and Run a Sample Application by Using the Rules Dictionary Editor Component
26.3.3
How to Deploy a Rules Dictionary Application to a Standalone Oracle WebLogic Server
26.3.4
What You May Need to Know About the Supported Attributes of the Rules Dictionary Editor Component
26.4
Using the Oracle Business Rules Dictionary Editor Task Flow
26.4.1
Introduction to the Oracle Business Rules Dictionary Task Flow
26.4.2
How to Create and Run a Sample Application By Using the Rules Dictionary Editor Task Flow
26.4.3
How to Deploy a Rules Dictionary Editor Task Flow Application to a Standalone Oracle WebLogic Server
26.5
Localizing the ADF-Based Web Application
26.6
Working with Translations
26.6.1
Enabling Translations for Consumer of Reusable Rules UI ADF Task Flow Component
26.6.2
Enabling Translations for Consumer of Rules Web UI Application
Part V Using the Human Workflow Service Component
27
Getting Started with Human Workflow
27.1
Introduction to Human Workflow
27.2
Introduction to Human Workflow Concepts
27.2.1
Introduction to Design and Runtime Concepts
27.2.1.1
Task Assignment and Routing
27.2.1.2
Static, Dynamic, and Rule-Based Task Assignment
27.2.1.3
Task Stakeholders
27.2.1.4
Task Deadlines
27.2.1.5
Notifications
27.2.1.6
Task Forms
27.2.1.7
Advanced Concepts
27.2.1.8
Reports and Audit Trails
27.2.2
Introduction to the Stages of Human Workflow Design
27.3
Introduction to Human Workflow Features
27.3.1
Human Workflow Use Cases
27.3.1.1
Task Assignment to a User or Role
27.3.1.2
Use of the Various Participant Types
27.3.1.3
Escalation, Expiration, and Delegation
27.3.1.4
Automatic Assignment and Delegation
27.3.1.5
Dynamic Assignment of Users Based on Task Content
27.4
Introduction to Human Workflow Architecture
27.4.1
Human Workflow Services
27.4.2
Use of Human Task
27.4.3
Service Engines
28
Creating Human Tasks
28.1
Introduction to Human Tasks
28.1.1
Introduction to Creating a Human Task Definition
28.1.2
Introduction to Associating the Human Task Definition with a BPEL Process
28.1.3
Introduction to Generating the Task Form
28.2
Creating Human Tasks
28.2.1
How to Create a Human Task Using the SOA Composite Editor
28.2.2
How to Create a Human Task Using Oracle BPEL Designer
28.2.3
What Happens When You Create a Human Task
28.3
Exiting the Human Task Editor and Saving Your Changes
28.4
Associating Human Tasks with BPEL Processes
28.4.1
How to Associate a Human Task with a BPEL Process
28.4.2
What You May Need to Know About Deleting a Wire Between a Human Task and a BPEL Process
28.4.3
How to Define the Human Task Activity Title, Initiator, Priority, and Parameter Variables
28.4.3.1
Specifying the Task Title
28.4.3.2
Specifying the Task Initiator and Task Priority
28.4.3.3
Specifying Task Parameters
28.4.4
How to Define the Human Task Activity Advanced Features
28.4.4.1
Specifying a Scope Name and a Global Task Variable Name
28.4.4.2
Specifying a Task Owner
28.4.4.3
Specifying an Identification Key
28.4.4.4
Specifying an Identity Context
28.4.4.5
Specifying an Application Context
28.4.4.6
Including the Task History of Other Human Tasks
28.4.5
How to View the Generated Human Task Activity
28.4.5.1
Invoking BPEL Callbacks
28.4.6
What You May Need to Know About Changing the Generated Human Task Activity
28.4.7
What You May Need to Know About Deleting a Partner Link Generated by a Human Task
28.4.8
How to Define Outcome-Based Modeling
28.4.8.1
Specifying Payload Updates
28.4.8.2
Using Case Statements for Other Task Conclusions
28.4.9
What You May Need to Know About Encoding an Attachment
29
Configuring Human Tasks
29.1
Accessing the Sections of the Human Task Editor
29.1.1
How to Access the Sections of the Human Task Editor
29.2
Specifying the Title, Description, Outcome, Priority, Category, Owner, and Application Context
29.2.1
How to Specify the Title, Description, Outcome, Priority, Category, Owner, and Application Context
29.2.2
How to Specify a Task Title
29.2.3
How to Specify a Task Description
29.2.4
How to Specify a Task Outcome
29.2.5
How to Specify a Task Priority
29.2.6
How to Specify a Task Category
29.2.7
How to Specify a Task Owner
29.2.7.1
Specifying a Task Owner Statically Through the User Directory or a List of Application Roles
29.2.7.2
Specifying a Task Owner Dynamically Through an XPath Expression
29.2.8
How To Specify an Application Context
29.3
Specifying the Task Payload Data Structure
29.3.1
How to Specify the Task Payload Data Structure
29.4
Assigning Task Participants
29.4.1
How to Specify a Stage Name and Add Parallel and Sequential Blocks
29.4.2
How to Assign Task Participants
29.4.3
How to Configure the Single Participant Type
29.4.3.1
Creating a Single Task Participant List
29.4.3.2
Specifying a Time Limit for Acting on a Task
29.4.3.3
Inviting Additional Participants to a Task
29.4.3.4
Bypassing a Task Participant
29.4.4
How to Configure the Parallel Participant Type
29.4.4.1
Specifying the Voting Outcome
29.4.4.2
Creating a Parallel Task Participant List
29.4.4.3
Specifying a Time Limit for Acting on a Task
29.4.4.4
Inviting Additional Participants to a Task
29.4.4.5
Bypassing a Task Participant
29.4.5
How to Configure the Serial Participant Type
29.4.5.1
Creating a Serial Task Participant List
29.4.5.2
Specifying a Time Limit for Acting on a Task
29.4.5.3
Inviting Additional Participants to a Task
29.4.5.4
Bypassing a Task Participant
29.4.6
How to Configure the FYI Participant Type
29.4.6.1
Creating an FYI Task Participant List
29.5
Selecting a Routing Policy
29.5.1
How to Route Tasks to All Participants in the Specified Order
29.5.1.1
Allowing All Participants to Invite Other Participants
29.5.1.2
Stopping Routing of a Task to Further Participants
29.5.1.3
Enabling Early Completion in Parallel Subtasks
29.5.1.4
Completing Parent Subtasks of Early Completing Subtasks
29.5.2
How to Specify Advanced Task Routing Using Business Rules
29.5.2.1
Introduction to Advanced Task Routing Using Business Rules
29.5.2.2
Facts
29.5.2.3
Action Types
29.5.2.4
Sample Ruleset
29.5.2.5
Linked Dictionary Support
29.5.2.6
Creating Advanced Routing Rules
29.5.3
How to Use External Routing
29.5.4
How to Configure the Error Assignee
29.6
Specifying Multilingual Settings and Style Sheets
29.6.1
How to Specify WordML and Other Style Sheets for Attachments
29.6.2
How to Specify Multilingual Settings
29.7
Escalating, Renewing, or Ending the Task
29.7.1
Introduction to Escalation and Expiration Policy
29.7.2
How to Specify a Policy to Never Expire
29.7.3
How to Specify a Policy to Expire
29.7.4
How to Extend an Expiration Policy Period
29.7.5
How to Escalate a Task Policy
29.7.6
How to Specify Escalation Rules
29.7.7
How to Specify a Due Date
29.8
Specifying Participant Notification Preferences
29.8.1
How to Notify Recipients of Changes to Task Status
29.8.2
How to Edit the Notification Message
29.8.3
How to Set Up Reminders
29.8.4
How to Change the Character Set Encoding
29.8.5
How to Secure Notifications to Exclude Details
29.8.6
How to Display the Oracle BPM Worklist URL in Notifications
29.8.7
How to Make Email Messages Actionable
29.8.8
How to Send Task Attachments with Email Notifications
29.8.9
How to Send Email Notifications to Groups and Application Roles
29.8.10
How to Customize Notification Headers
29.9
Specifying Access Policies and Task Actions on Task Content
29.9.1
How to Specify Access Policies on Task Content
29.9.1.1
Introduction to Access Rules
29.9.1.2
Specifying User Privileges for Acting on Task Content
29.9.1.3
Specifying Actions for Acting Upon Tasks
29.9.2
How to Specify a Workflow Digital Signature Policy
29.9.2.1
Specifying a Certificate Authority
29.10
Specifying Restrictions on Task Assignments
29.10.1
How to Specify Restrictions on Task Assignments
29.11
Specifying Java or Business Event Callbacks
29.11.1
How to Specify Callback Classes on Task Status
29.11.1.1
Specifying Java Callbacks
29.11.1.2
Specifying Business Event Callbacks
29.11.2
How to Specify Task and Routing Customizations in BPEL Callbacks
29.11.3
How to Disable BPEL Callbacks
29.12
Storing Documents in Oracle Enterprise Content Management
30
Designing Task Forms for Human Tasks
30.1
Introduction to the Task Form
30.1.1
What You May Need to Know About Task Forms: Time Zone Conversion
30.2
Associating the Task Flow with the Task Service
30.3
Creating an ADF Task Flow Based on a Human Task
30.3.1
How To Create an ADF Task Flow from the Human Task Editor
30.3.2
How To Create an ADF Task Flow Based on a Human Task
30.3.3
What Happens When You Create an ADF Task Flow Based on a Human Task
30.3.4
What You May Need to Know About Having Multiple ADF Task Flows That Contain the Same Element with Different Meta-attributes
30.4
Creating a Task Form
30.4.1
How To Create an Autogenerated Task Form
30.4.2
How to Register the Library JAR File for Custom Page Templates
30.4.3
How To Create a Task Form Using the Custom Task Form Wizard
30.4.4
How To Create a Task Form Using the Complete Task with Payload Drop Handler
30.4.5
How To Create Task Form Regions Using Individual Drop Handlers
30.4.6
How To Add the Payload to the Task Form
30.4.7
What Happens When You Create a Task Form
30.5
Refreshing Data Controls When the Task XSD Changes
30.6
Securing the Task Flow Application
30.7
Creating an Email Notification
30.7.1
How To Create an Email Notification
30.7.1.1
Creating a Task Flow with a Router
30.7.1.2
Creating an Email Notification Page
30.7.2
What Happens When You Create an Email Notification Page
30.7.3
What You May Need to Know About Creating an Email Notification Page
30.8
Deploying a Composite Application with a Task Flow
30.8.1
How To Deploy a Composite Application with a Task Flow
30.8.2
How To Redeploy the Task Form
30.8.3
How To Deploy a Task Flow as a Separate Application
30.8.4
How To Deploy a Task Form to a non-SOA Oracle WebLogic Server
30.8.4.1
Before Deploying the Task Form: Port Changes
30.8.4.2
Configuring Unique Cookie Context Paths for the Session Tracking Cookies
30.8.4.3
Deploying oracle.soa.workflow.jar to a non-SOA Oracle WebLogic Server
30.8.4.4
Defining the Foreign JNDI Provider on a non-SOA Oracle WebLogic Server
30.8.4.5
Defining the Foreign JNDI Provider Links on a non-SOA Oracle WebLogic Server
30.8.4.6
Including a Grant for bpm-services.jar
30.8.4.7
Deploying the Application
30.8.5
What Happens When You Deploy the Task Form
30.8.6
What You May Need to Know About Undeploying a Task Flow
30.9
Displaying a Task Form in the Worklist
30.9.1
How To Display the Task Form in the Worklist
30.10
Displaying a Task in an Email Notification
30.10.1
Changing the Text for the Worklist Application in Task Notifications
30.10.2
Changing the URL of the Worklist Application in Task Notifications
30.10.3
Showing or Hiding the URL of the Worklist Application in Task Notifications
30.11
Reusing the Task Flow Application with Multiple Human Tasks
30.11.1
How To Reuse the Task Flow Application with Multiple Human Tasks
30.11.2
How to Reuse the Task Flow Application with Different Actions
31
Human Workflow Tutorial
31.1
Introduction to the Human Workflow Tutorial
31.2
Prerequisites
31.3
Creating an Application and a Project with a BPEL Process
31.4
Creating the Human Task Service Component
31.5
Designing the Human Task
31.6
Associating the Human Task and BPEL Process Service Components
31.7
Creating an Application Server Connection
31.8
Deploying the SOA Composite Application
31.9
Initiating the Process Instance
31.10
Creating a Task Form Project
31.11
Acting on the Task in Oracle BPM Worklist
31.12
Deploying the Task Form
31.13
Additional Tutorials
32
Using Oracle BPM Worklist
32.1
Introduction to Oracle BPM Worklist
32.1.1
What You May Need To Know About Oracle BPM Worklist
32.2
Logging In to Oracle BPM Worklist
32.2.1
How To Log In to the Worklist
32.2.1.1
Enabling the weblogic User for Logging in to the Worklist
32.2.2
What Happens When You Log In to the Worklist
32.2.3
What Happens When You Change a User's Privileges While They are Logged in to Oracle BPM Worklist
32.3
Customizing the Task List Page
32.3.1
How To Filter Tasks
32.3.2
How To Create, Delete, and Customize Worklist Views
32.3.3
How To Customize the Task Status Chart
32.3.4
How To Create a ToDo Task
32.3.5
How to Create Subtasks in Worklist Application
32.3.5.1
What You May Need to Know About Creating Subtasks
32.4
Acting on Tasks: The Task Details Page
32.4.1
System Actions
32.4.2
Task History
32.4.3
How To Act on Tasks
32.4.4
How To Act on Tasks That Require a Digital Signature
32.5
Approving Tasks
32.6
Setting a Vacation Period
32.7
Setting Rules
32.7.1
How To Create User Rules
32.7.2
How To Create Group Rules
32.7.3
Assignment Rules for Tasks with Multiple Assignees
32.8
Using the Worklist Administration Functions
32.8.1
How To Manage Other Users' or Groups' Rules (as an Administrator)
32.8.2
How to Specify the Login Page Realm Label
32.8.3
How to Specify the Resource Bundle
32.8.4
How to Specify the Language Locale Information
32.8.5
How to Specify a Branding Logo
32.8.6
How to Specify the Branding Title
32.8.7
How to Choose a Skin
32.8.8
How to Enable Customized Applications and Links
32.8.9
How to Specify an Image for a Task Action
32.9
Specifying Notification Settings
32.9.1
Messaging Filter Rules
32.9.1.1
Data Types
32.9.1.2
Attributes
32.9.2
Rule Actions
32.9.3
Managing Messaging Channels
32.9.3.1
Viewing Your Messaging Channels
32.9.3.2
Creating, Editing, and Deleting a Messaging Channel
32.9.4
Managing Messaging Filters
32.9.4.1
Viewing Messaging Filters
32.9.4.2
Creating Messaging Filters
32.9.4.3
Editing a Messaging Filter
32.9.4.4
Deleting a Messaging Filter
32.10
Using Mapped Attributes (Flex Fields)
32.10.1
How To Map Attributes
32.10.2
Custom Mapped Attributes
32.11
Creating Worklist Reports
32.11.1
How To Create Reports
32.11.2
What Happens When You Create Reports
32.11.2.1
Unattended Tasks Report
32.11.2.2
Tasks Priority Report
32.11.2.3
Tasks Cycle Time Report
32.11.2.4
Tasks Productivity Report
32.12
Accessing Oracle BPM Worklist in Local Languages and Time Zones
32.12.1
Strings in Oracle BPM Worklist
32.12.2
How to Change the Preferred Language, Display Names of Users, and Time Zone Settings if the Identity Store is LDAP-Based
32.12.3
How to Change the Language in Which Tasks Are Displayed
32.12.4
How To Change the Language Preferences from a JAZN XML File
32.12.5
What You May Need to Know Setting Display Languages in Worklist
32.12.6
How To Change the Time Zone Used in the Worklist
32.13
Creating Reusable Worklist Regions
32.13.1
How to Create an Application With an Embedded Reusable Worklist Region
32.13.2
How to Set Up the Deployment Profile
32.13.3
How to Prepare Federated Mode Task Flows For Deployment
32.13.4
What You May Need to Know About Task List Task Flow
32.13.5
What You May Need to Know About Certificates Task Flow
32.13.6
What You May Need to Know About the Reports Task Flow
32.13.7
What You May Need to Know About Application Preferences Task Flow
32.13.8
What You May Need to Know About Mapped Attributes Task Flow
32.13.9
What You May Need to Know About Rules Task Flow
32.13.10
What You May Need to Know About Approval Groups Task Flow
32.13.11
What You May Need to Know About Task Configuration Task Flow
32.14
Java Code for Enabling Customized Applications in Worklist Application
33
Building a Custom Worklist Client
33.1
Introduction to Building Clients for Workflow Services
33.2
Packages and Classes for Building Clients
33.3
Workflow Service Clients
33.3.1
The IWorkflowServiceClient Interface
33.4
Class Paths for Clients Using SOAP
33.5
Class Paths for Clients Using Remote EJBs
33.6
Initiating a Task
33.6.1
Creating a Task
33.6.2
Creating a Payload Element in a Task
33.6.3
Initiating a Task Programmatically
33.7
Changing Workflow Standard View Definitions
33.8
Writing a Worklist Application Using the HelpDeskUI Sample
34
Introduction to Human Workflow Services
34.1
Introduction to Human Workflow Services
34.1.1
SOAP, Enterprise JavaBeans, and Java Support for the Human Workflow Services
34.1.1.1
Support for Foreign JNDI Names
34.1.2
Security Model for Services
34.1.2.1
Limitation on Propagating Identity to Workflow Services when Using SOAP Web Services
34.1.2.2
Creating Human Workflow Context on Behalf of a User
34.1.2.3
Obtaining the Workflow Context for a User Previously Authenticated by a JAAS Application
34.1.3
Task Service
34.1.4
Task Query Service
34.1.5
Identity Service
34.1.5.1
Identity Service Providers
34.1.6
Task Metadata Service
34.1.7
User Metadata Service
34.1.8
Task Report Service
34.1.9
Runtime Config Service
34.1.9.1
Internationalization of Attribute Labels
34.1.10
Evidence Store Service and Digital Signatures
34.1.10.1
Prerequisites
34.1.10.2
Interfaces and Methods
34.1.11
Task Instance Attributes
34.2
Notifications from Human Workflow
34.2.1
Contents of Notification
34.2.2
Error Message Support
34.2.3
Reliability Support
34.2.4
Management of Oracle Human Workflow Notification Service
34.2.5
How to Configure the Notification Channel Preferences
34.2.6
How to Configure Notification Messages in Different Languages
34.2.7
How to Send Actionable Messages
34.2.7.1
How to Send Actionable Emails for Human Tasks
34.2.8
How to Send Inbound and Outbound Attachments
34.2.9
How to Send Inbound Comments
34.2.10
How to Send Secure Notifications
34.2.11
How to Set Channels Used for Notifications
34.2.12
How to Send Reminders
34.2.13
How to Set Automatic Replies to Unprocessed Messages
34.2.14
How to Create Custom Notification Headers
34.3
Assignment Service Configuration
34.3.1
Dynamic Assignment and Task Escalation Patterns
34.3.1.1
How to Implement a Dynamic Assignment Pattern
34.3.1.2
How to Configure Dynamic Assignment Patterns
34.3.1.3
How to Configure Display Names for Dynamic Assignment Patterns
34.3.1.4
How to Implement a Task Escalation Pattern
34.3.2
Dynamically Assigning Task Participants with the Assignment Service
34.3.2.1
How to Implement an Assignment Service
34.3.2.2
Example of Assignment Service Implementation
34.3.2.3
How to Deploy a Custom Assignment Service
34.3.3
Custom Escalation Function
34.4
Class Loading for Callbacks and Resource Bundles
34.5
Resource Bundles in Workflow Services
34.5.1
Task Resource Bundles
34.5.2
Global Resource Bundle – WorkflowLabels.properties
34.5.3
Worklist Client Resource Bundles
34.5.4
Task Detail ADF Task Flow Resource Bundles
34.5.5
Specifying Stage and Participant Names in Resource Bundles
34.5.6
Case Sensitivity in Group and Application Role Names
34.6
Introduction to Human Workflow Client Integration with Oracle WebLogic Server Services
34.6.1
Human Workflow Services Clients
34.6.1.1
Task Query Service Client Code
34.6.1.2
Configuration Option
34.6.1.3
Client Logging
34.6.1.4
Configuration Migration Utility
34.6.2
Identity Propagation
34.6.2.1
Enterprise JavaBeans Identity Propagation
34.6.2.2
SAML Token Identity Propagation for SOAP Client
34.6.2.3
Public Key Alias
34.6.3
Client JAR Files
34.7
Task States in a Human Task
34.8
Database Views for Oracle Workflow
34.8.1
Unattended Tasks Report View
34.8.2
Task Cycle Time Report View
34.8.3
Task Productivity Report View
34.8.4
Task Priority Report View
35
Integrating Microsoft Excel with a Human Task
35.1
Configuring Your Environment for Invoking a BPEL Process from an Excel Workbook
35.1.1
How to Create an Oracle JDeveloper Project of the Type Web Service Data Control
35.1.2
How to Create a Dummy JSF Page
35.1.3
How to Add Desktop Integration to Your Oracle JDeveloper Project
35.1.4
What Happens When You Add Desktop Integration to Your Oracle JDeveloper Project
35.1.5
How to Deploy the Web Application You Created in Step 1
35.1.6
How to Install Microsoft Excel
35.1.7
How to Install the Oracle ADF-Desktop Integration Plug-in
35.1.8
How to Specify the User Interface Controls and Create the Excel Workbook
35.2
Attaching Excel Workbooks to Human Task Workflow Email Notifications
35.2.1
Enabling Attachment of Excel Workbooks to Human Task Workflow Email Notifications
35.2.2
What Happens During Runtime When You Enable Attachment of Excel Workbooks to Human Task Workflow Email Notifications
35.2.3
Example: Attaching an Excel Workbook to Email Notifications
35.2.3.1
Task 1: Enable the ADF Task Flow Project with Oracle ADF-DI Capabilities
35.2.3.2
Task 2: Set up Authentication
35.2.3.3
Task 3: Create a Valid Page Definition File to Be Used in the Excel Workbook
35.2.3.4
Task 4: Prepare the Excel Workbook
35.2.3.5
Task 5: Deploy the ADF Task Flow
35.2.3.6
Task 6: Test the Deployed Application
36
Configuring Task List Portlets
36.1
Introduction to Task List Portlets
36.2
Deploying the Task List Portlet Producer Application to a Portlet Server
36.2.1
Deployment Prerequisites
36.2.2
How to Deploy the Task List Portlet Producer Application
36.2.3
How to Connect the Task List Producer to the Remote SOA Server
36.2.3.1
How to Define the Foreign JNDI on the Oracle WebCenter Portal Oracle WebLogic Server
36.2.3.2
How to Configure EJB Identity Propagation
36.2.3.3
How to Configure the Identity Store
36.2.4
How to Secure the Task List Portlet Producer Application Using Web Services Security
36.2.5
How to Specify the Inbound Security Policy
36.3
Creating a Portlet Consumer Application for Embedding the Task List Portlet
36.3.1
How To Create a Portlet Consumer Application for Embedding the Task List Portlet
36.4
Passing Worklist Portlet Parameters
36.4.1
Assignment Filter Constraints
36.4.2
Example of File Containing All Column Constants
Part VI Using Binding Components
37
Getting Started with Binding Components
37.1
Introduction to Binding Components
37.1.1
Web Services
37.1.1.1
WS-AtomicTransaction Support
37.1.2
HTTP Binding Service
37.1.2.1
Supported Interactions
37.1.2.2
How to Configure the HTTP Binding Service
37.1.2.3
How to Enable Basic Authentication for HTTP Binding
37.1.3
JCA Adapters
37.1.3.1
AQ Adapter
37.1.3.2
Database Adapter
37.1.3.3
File Adapter
37.1.3.4
FTP Adapter
37.1.3.5
JMS Adapter
37.1.3.6
MQ Adapter
37.1.3.7
Socket Adapter
37.1.3.8
Third Party Adapter
37.1.3.9
Oracle User Messaging Service Adapter
37.1.4
Oracle Applications Adapter
37.1.5
Oracle BAM Adapter
37.1.6
Oracle B2B
37.1.7
Oracle Healthcare Adapter
37.1.8
ADF-BC Services
37.1.9
EJB Services
37.1.10
Direct Binding Services
37.2
Introduction to Integrating a Binding Component in a SOA Composite Application
37.2.1
How to Integrate a Binding Component in a SOA Composite Application
37.2.2
How to Use ADF Binding to Invoke a Composite Application from a JSP/Java Class
37.3
Creating Tokens for Use in the Binding URLs of External References
37.3.1
How to Create Tokens for Use in the Binding URLs of External References
38
Integrating Enterprise JavaBeans with SOA Composite Applications
38.1
Introduction to Enterprise JavaBeans Binding Integration with SOA Composite Applications
38.1.1
Integration Through SDO-Based EJBs
38.1.2
Integration Through Java Interfaces
38.2
Designing an SDO-Based Enterprise JavaBeans Application
38.2.1
How to Create SDO Objects Using the SDO Compiler
38.2.2
How to Create a Session Bean and Import the SDO Objects
38.2.3
How to Create a Profile and an EAR File
38.2.4
How to Define the SDO Types with an Enterprise JavaBeans Bean
38.2.5
How to Use Web Service Annotations
38.2.6
How to Deploy the Enterprise JavaBeans EAR File
38.3
Creating an Enterprise JavaBeans Service in Oracle JDeveloper
38.3.1
How to Integrate SDO-based Enterprise JavaBeans with SOA Composite Applications
38.3.2
How to Integrate Java Interface-based Enterprise JavaBeans with SOA Composite Applications
38.4
Designing an SDO-Based Enterprise JavaBeans Client to Invoke Oracle SOA Suite
38.5
Specifying Enterprise JavaBeans Roles
38.6
Configuring Enterprise JavaBeans Binding Support in the Credential Store Framework
38.6.1
How to Configure Enterprise JavaBeans Binding Support in the Credential Store Framework
39
Using the Direct Binding Invocation API
39.1
Introduction to Direct Binding
39.1.1
Direct Service Binding Component
39.1.2
Direct Reference Binding Component
39.2
Introduction to the Direct Binding Invocation API
39.2.1
Synchronous Direct Binding Invocation
39.2.2
Asynchronous Direct Binding Invocation
39.2.3
SOA Direct Address Syntax
39.2.4
SOA Transaction Propagation
39.3
Invoking a SOA Composite Application in Oracle JDeveloper with the Invocation API
39.3.1
How to Create an Inbound Direct Binding Service
39.3.2
How to Create an Outbound Direct Binding Reference
39.3.3
How to Set an Identity for J2SE Clients Invoking Direct Binding
39.3.4
What You May Need to Know About Invoking SOA Composites on Hosts with the Same Server and Domain Names
39.4
Samples Using the Direct Binding Invocation API
Part VII Sharing Functionality Across Service Components
40
Creating Transformations with the XSLT Mapper
40.1
Introduction to the XSLT Mapper
40.1.1
Overview of XSLT Creation
40.1.2
Guidelines for Using the XSLT Mapper
40.2
Creating an XSL Map File
40.2.1
How to Create an XSL Map File in Oracle BPEL Process Manager
40.2.2
How to Create an XSL Map File from Imported Source and Target Schema Files in Oracle BPEL Process Manager
40.2.3
How to Create an XSL Map File in Oracle Mediator
40.2.4
What You May Need to Know About Creating an XSL Map File
40.2.5
What You May Need to Know About Importing a Composite with an XSL File
40.2.6
What Happens at Runtime If You Pass a Payload Through Oracle Mediator Without Creating an XSL Map File
40.2.7
What Happens If You Receive an Empty Namespace Tag in an Output Message
40.3
Designing Transformation Maps with the XSLT Mapper
40.3.1
How to Add Additional Sources
40.3.2
How to Perform a Simple Copy by Linking Nodes
40.3.3
How to Set Constant Values
40.3.4
How to Add Functions
40.3.4.1
Editing Function Parameters
40.3.4.2
Chaining Functions
40.3.4.3
Using Named Templates
40.3.4.4
Importing User-Defined Functions
40.3.5
How to Edit XPath Expressions
40.3.6
How to Add XSLT Constructs
40.3.6.1
Using Conditional Processing with xsl:if
40.3.6.2
Using Conditional Processing with xsl:choose
40.3.6.3
Creating Loops with xsl:for-each
40.3.6.4
Cloning xsl:for-each
40.3.6.5
Applying xsl:sort to xsl:for-each
40.3.6.6
Copying Nodes with xsl:copy-of
40.3.6.7
Including External Templates with xsl:include
40.3.7
How to Automatically Map Nodes
40.3.7.1
Using Auto Mapping with Confirmation
40.3.8
What You May Need to Know About Automatic Mapping
40.3.9
How to View Unmapped Target Nodes
40.3.10
How to Generate and Use Dictionaries
40.3.11
What You May Need to Know About Generating Dictionaries in Which Functions are Used
40.3.12
How to Create Map Parameters and Variables
40.3.12.1
Creating a Map Parameter
40.3.12.2
Creating a Map Variable
40.3.13
How to Search Source and Target Nodes
40.3.14
How to Control the Generation of Unmapped Target Elements
40.3.15
How to Ignore Elements in the XSLT Document
40.3.16
How to Import a Customization File to Specify Display Preferences in the XSLT Mapper
40.3.17
How to Replace a Schema in the XSLT Mapper
40.3.18
How to Substitute Elements and Types in the Source and Target Trees
40.3.19
How to Resolve Low Memory Issues in the XSLT Mapper
40.4
Testing the Map
40.4.1
How to Test the Transformation Mapping Logic
40.4.2
How to Generate Reports
40.4.2.1
Correcting Memory Errors When Generating Reports
40.4.3
How to Customize Sample XML Generation
40.5
Demonstrating Features of the XSLT Mapper
40.5.1
How To Open the Application
40.5.2
How To Create a New XSLT Map in the BPEL Process
40.5.3
How To Use Type Substitution to Map the Purchase Order Items
40.5.4
How To Reference Additional Source Elements
40.5.5
How To Use Element Substitution to Map the Shipping Address
40.5.6
How To Map the Remaining Fields
40.5.7
How To Test the Map
41
Using Business Events and the Event Delivery Network
41.1
Introduction to Business Events
41.1.1
Local and Remote Events Boundaries
41.1.2
Events Published and Subscribed to in the Same Process Are Not Delivered
41.2
Creating Business Events in Oracle JDeveloper
41.2.1
How to Create a Business Event
41.3
Subscribing to or Publishing a Business Event from an Oracle Mediator Service Component
41.3.1
How to Subscribe to a Business Event
41.3.2
What Happens When You Create and Subscribe to a Business Event
41.3.3
What You May Need to Know About Subscribing to a Business Event
41.3.4
How to Publish a Business Event
41.3.5
How to Configure a Foreign JNDI Provider to Enable Administration Server Applications to Publish Events to the SOA Server
41.3.6
How to Configure JMS-based EDN Implementations
41.3.7
What Happens When You Publish a Business Event
41.4
Subscribing to or Publishing a Business Event from a BPEL Process Service Component
41.4.1
How to Subscribe to a Business Event
41.4.2
How to Publish a Business Event
41.4.3
What Happens When You Subscribe to and Publish a Business Event
41.4.4
What You May Need to Know About Subscribing to a Business Event
41.5
How to Integrate Oracle ADF Business Component Business Events with Oracle Mediator
Part VIII Completing Your Application
42
Enabling Security with Policies
42.1
Introduction to Policies
42.2
Attaching Policies to Binding Components and Service Components
42.2.1
How to Attach Policies to Binding Components and Service Components
42.2.2
How to Override Policy Configuration Property Values
42.2.2.1
Overriding Client Configuration Property Values
42.2.2.2
Overriding Server Configuration Property Values
43
Deploying SOA Composite Applications
43.1
Introduction to Deployment
43.2
Deployment Prerequisites
43.2.1
Creating the Oracle SOA Suite Schema
43.2.2
Creating a SOA Domain
43.2.3
Configuring a SOA Cluster
43.3
Understanding the Packaging Impact
43.4
Anatomy of a Composite
43.5
Preparing the Target Environment
43.5.1
How to Create Data Sources and Queues
43.5.1.1
Script for Creation of JMS Resource and Redeployment of JMS Adapter
43.5.1.2
Script for Creation of the Database Resource and Redeployment of the Database Adapter
43.5.2
How to Create Connection Factories and Connection Pooling
43.5.3
How to Enable Security
43.5.4
How to Set the Composite Instance Name at Design Time
43.5.4.1
Setting the Composite Instance Name in Oracle Mediator
43.5.4.2
Setting the Composite Instance Name in a BPEL Process
43.5.5
How to Deploy Trading Partner Agreements and Task Flows
43.5.6
How to Create an Application Server Connection
43.5.7
How to Create a SOA-MDS Connection
43.5.7.1
What You May Need to Know About Opening the composite.xml File Through a SOA-MDS Connection
43.6
Customizing Your Application for the Target Environment Before Deployment
43.6.1
How to Use Configuration Plans to Customize SOA Composite Applications for the Target Environment
43.6.1.1
Introduction to Configuration Plans
43.6.1.2
Introduction to a Configuration Plan File
43.6.1.3
Introduction to Use Cases for a Configuration Plan
43.6.1.4
How to Create a Configuration Plan in Oracle JDeveloper
43.6.1.5
How to Create a Configuration Plan with the WLST Utility
43.6.1.6
How to Attach a Configuration Plan with ant Scripts
43.6.1.7
How to Create Global Token Variables
43.7
Deploying SOA Composite Applications
43.7.1
How to Deploy a Single SOA Composite in Oracle JDeveloper
43.7.1.1
Creating an Application Server Connection
43.7.1.2
Optionally Creating a Project Deployment Profile
43.7.1.3
Deploying the Profile
43.7.1.4
What You May Need to Know About Deploying Human Task Composites with Task Flows to Partitions
43.7.2
How to Deploy Multiple SOA Composite Applications in Oracle JDeveloper
43.7.3
How to Deploy and Use Shared Data Across Multiple SOA Composite Applications in Oracle JDeveloper
43.7.3.1
Create a JAR Profile and Include the Artifacts to Share
43.7.3.2
Create a SOA Bundle that Includes the JAR Profile
43.7.3.3
Deploy the SOA Bundle with Oracle JDeveloper
43.7.3.4
Use Shared Data
43.7.4
How to Deploy an Existing SOA Archive in Oracle JDeveloper
43.7.5
How to Manage SOA Composite Applications with the WLST Utility
43.7.6
How to Manage SOA Composite Applications with ant Scripts
43.7.6.1
How to Use ant to Automate the Testing of a SOA Composite Application
43.7.6.2
How to Use ant to Compile a SOA Composite Application
43.7.6.3
How to Use ant to Package a SOA Composite Application into a Composite SAR File
43.7.6.4
How to Use ant to Deploy a SOA Composite Application
43.7.6.5
How to Use ant to Undeploy a SOA Composite Application
43.7.6.6
How to Use ant to Export a Composite into a SAR File
43.7.6.7
How to Use ant to Export Postdeployment Changes of a Composite into a JAR File
43.7.6.8
How to Use ant to Import Postdeployment Changes of a Composite
43.7.6.9
How to Use ant to Export Shared Data of a Given Pattern into a JAR File
43.7.6.10
How to Use ant to Remove a Top-level Shared Data Folder
43.7.6.11
How to Use ant to Start a SOA Composite Application
43.7.6.12
How to Use ant to Stop a SOA Composite Application
43.7.6.13
How to Use ant to Activate a SOA Composite Application
43.7.6.14
How to Use ant to Retire a SOA Composite Application
43.7.6.15
How to Use ant to Assign the Default Version to a SOA Composite Application
43.7.6.16
How to Use ant to List the Deployed SOA Composite Applications
43.7.6.17
How to Use ant to List All Available Partitions in the SOA Infrastructure
43.7.6.18
How to Use ant to List All Composites in a Partition
43.7.6.19
How to Use ant to Create a Partition in the SOA Infrastructure
43.7.6.20
How to Use ant to Delete a Partition in the SOA Infrastructure
43.7.6.21
How to Use ant to Start All Composites in the Partition
43.7.6.22
How to Use ant to Stop All Composites in the Partition
43.7.6.23
How to Use ant to Activate All Composites in the Partition
43.7.6.24
How to Use ant to Retire All Composites in the Partition
43.7.6.25
How to Use ant to Upgrade a SOA Composite Application
43.7.6.26
How to Use ant to Manage SOA Composite Applications
43.7.7
How to Deploy SOA Composite Applications from Oracle Enterprise Manager Fusion Middleware Control
43.7.8
How to Deploy SOA Composite Applications to a Cluster
43.8
Postdeployment Configuration
43.8.1
Security
43.8.2
Updating Connections
43.8.3
Updating Data Sources and Queues
43.8.4
Attaching Policies
43.9
Testing and Troubleshooting
43.9.1
Verifying Deployment
43.9.2
Initiating an Instance of a Deployed Composite
43.9.3
Automating the Testing of Deployed Composites
43.9.4
Recompiling a Project After Receiving a Deployment Error
43.9.5
Reducing Java Code Size to Resolve Java Compilation Errors
43.9.6
Troubleshooting Common Deployment Errors
43.9.6.1
Common Oracle JDeveloper Deployment Issues
43.9.6.2
Common Configuration Plan Issues
43.9.6.3
Deploying to a Managed Oracle WebLogic Server
43.9.6.4
Deploying to a Two-Way, SSL-Enabled Oracle WebLogic Server
43.9.6.5
Deploying with an Unreachable Proxy Server
43.9.6.6
Releasing Locks to Resolve ADF Task Form EAR File Deployment Errors
43.9.6.7
Increasing Memory to Recover from Compilation Errors
43.9.6.8
Oracle JDeveloper Compilation Error When Property Alias Definition is Missing for a Receive Activity with a Correlation Set
44
Automating Testing of SOA Composite Applications
44.1
Introduction to the Composite Test Framework
44.1.1
Test Cases Overview
44.1.2
Overview of Test Suites
44.1.3
Overview of Emulations
44.1.4
Overview of Assertions
44.2
Introduction to the Components of a Test Suite
44.2.1
Process Initiation
44.2.2
Emulations
44.2.3
Assertions
44.2.4
Message Files
44.3
Creating Test Suites and Test Cases
44.3.1
How to Create Test Suites and Test Cases
44.4
Creating the Contents of Test Cases
44.4.1
How to Initiate Inbound Messages
44.4.2
How to Emulate Outbound Messages
44.4.3
How to Emulate Callback Messages
44.4.4
How to Emulate Fault Messages
44.4.5
How to Create Assertions
44.4.5.1
Creating Assertions on a Part Section, Nonleaf Element, or Entire XML Document
44.4.5.2
Creating Assertions on a Leaf Element
44.4.6
What You May Need to Know About Assertions
44.5
Testing BPEL Process Service Components
44.5.1
Overview of Assertions on BPEL Process Activities
44.5.2
Overview of a Fast Forward Action on a Wait Activity
44.5.3
Overview of Assert Activity Execution
44.5.4
How to Create BPEL Process Service Component Tests
44.5.5
How to Create Assertions
44.5.6
How to Bypass a Wait Activity
44.5.7
How to Specify the Number of Times to Execute an Activity
44.6
Deploying and Running a Test Suite
Part IX Advanced Topics
45
Managing Large Documents and Large Numbers of Instances
45.1
Best Practices for Handling Large Documents
45.1.1
Use Cases for Handling Large Documents
45.1.1.1
Passing Binary Objects as Base64-Encoded Text in XML Payloads
45.1.1.2
End-to-End Streaming with Attachments
45.1.1.3
Sending and Receiving MTOM-Optimized Messages to SOA Composite Applications
45.1.1.4
Processing Large XML with Repeating Constructs
45.1.1.5
Processing Large XML Documents with Complex Structures
45.1.2
Limitations on Concurrent Processing of Large Documents
45.1.2.1
Opaque Schema for Processing Large Payloads
45.1.3
General Tuning Recommendations
45.1.3.1
General Recommendations
45.1.3.2
Setting Audit Levels from Oracle Enterprise Manager for Large Payload Processing
45.1.3.3
Using the Assign Activity in Oracle BPEL Process Manager and Oracle Mediator
45.1.3.4
Using XSLT Transformations on Large Payloads (For Oracle BPEL Process Manager)
45.1.3.5
Using XSLT Transformations on Large Payloads (For Oracle Mediator)
45.1.3.6
Using XSLT Transformations for Repeating Structures
45.1.3.7
Processing Large Documents in Oracle B2B
45.1.3.8
Setting a Size Restriction on Inbound Web Service Message Size
45.1.3.9
Using XPath Functions to Write Large XSLT/XQuery Output to a File System
45.2
Best Practices for Handling Large Metadata
45.2.1
Boundary on the Processing of Large Numbers of Activities in a BPEL Process
45.2.2
Using Large Numbers of Activities in BPEL Processes (Without FlowN)
45.2.3
Using Large Numbers of Activities in BPEL Processes (With FlowN)
45.2.4
Using a Flow With Multiple Sequences
45.2.5
Using a Flow with One Sequence
45.2.6
Using a Flow with No Sequence
45.2.7
Large Numbers of Oracle Mediators in a Composite
45.2.8
Importing Large Data Sets in Oracle B2B
45.3
Best Practices for Handling Large Numbers of Instances
45.3.1
Instance and Rejected Message Deletion with the Purge Script
45.3.2
Improving the Loading of Pages in Oracle Enterprise Manager Fusion Middleware Control
46
Customizing SOA Composite Applications
46.1
Introduction to Customizing SOA Composite Applications
46.2
Creating the Customizable Composite
46.2.1
How to Create the Customizable Composite
46.2.2
How to Create Customization Classes
46.2.3
How to Add an XSD or WSDL File
46.2.4
How to Search for Customized Activities in a BPEL Process
46.2.5
What You May Need to Know About Editing Artifacts in a Customized Composite
46.2.6
What You May Need to Know About Resolving Validation Errors in Oracle JDeveloper
46.2.7
What You May Need to Know About Resolving a Sequence Conflict
46.2.8
What You May Need to Know About Compiling and Deploying a Customized Application
46.3
Customizing the Vertical Application
46.3.1
How to Customize the Vertical Application
46.4
Customizing the Customer Version
46.4.1
How to Customize the Customer Version
46.5
Upgrading the Composite
46.5.1
How to Upgrade the Core Application Team Composite
46.5.2
How to Upgrade the Vertical Application Team Composite
46.5.3
How to Upgrade the Customer Composite
47
Working with Domain Value Maps
47.1
Introduction to Domain Value Maps
47.1.1
Domain Value Map Features
47.1.1.1
Qualifier Domains
47.1.1.2
Qualifier Hierarchies
47.1.1.3
One-to-Many Mappings
47.2
Creating Domain Value Maps
47.2.1
How to Create Domain Value Maps
47.2.2
What Happens When You Create a Domain Value Map
47.3
Editing a Domain Value Map
47.3.1
How to Add Domains to a Domain Value Map
47.3.2
How to Edit a Domain
47.3.3
How to Add Domain Values to a Domain Value Map
47.3.4
How to Edit Domain Values
47.4
Using Domain Value Map Functions
47.4.1
Understanding Domain Value Map Functions
47.4.1.1
dvm:lookupValue
47.4.1.2
dvm:lookupValue1M
47.4.2
How to Use Domain Value Map Functions in Transformations
47.4.3
How to Use Domain Value Map Functions in XPath Expressions
47.4.4
What Happens at Runtime
47.5
Creating a Domain Value Map Use Case for a Hierarchical Lookup
47.5.1
How to Create the HierarchicalValue Use Case
47.5.1.1
Task 1: How to Create an Oracle JDeveloper Application and a Project
47.5.1.2
Task 2: How to Create a Domain Value Map
47.5.1.3
Task 3: How to Create a File Adapter Service
47.5.1.4
Task 4: How to Create ProcessOrders Mediator Component
47.5.1.5
Task 5: How to Create a File Adapter Reference
47.5.1.6
Task 6: How to Specify Routing Rules
47.5.1.7
Task 7: How to Configure an Application Server Connection
47.5.1.8
Task 8: How to Deploy the Composite Application
47.5.2
How to Run and Monitor the HierarchicalValue Application
47.6
Creating a Domain Value Map Use Case For Multiple Values
47.6.1
How to Create the Multivalue Use Case
47.6.1.1
Task 1: How to Create an Oracle JDeveloper Application and Project
47.6.1.2
Task 2: How to Create a Domain Value Map
47.6.1.3
Task 3: How to Create a File Adapter Service
47.6.1.4
Task 4: How to Create the LookupMultiplevaluesMediator Mediator
47.6.1.5
Task 5: How to Create a File Adapter Reference
47.6.1.6
Task 6: How to Specify Routing Rules
47.6.1.7
Task 7: How to Configure an Application Server Connection
47.6.1.8
Task 8: How to Deploy the Composite Application
47.6.2
How to Run and Monitor the Multivalue Application
48
Using Oracle SOA Composer with Domain Value Maps
48.1
Introduction to Oracle SOA Composer
48.1.1
How to Log in to Oracle SOA Composer
48.2
Viewing Domain Value Maps at Runtime
48.2.1
How To View Domain Value Maps at Runtime
48.3
Editing Domain Value Maps at Runtime
48.3.1
How to Edit Domain Value Maps at Runtime
48.3.1.1
Changing to Edit Mode
48.3.1.2
Adding Rows
48.3.1.3
Editing Rows
48.3.1.4
Deleting Rows
48.4
Saving Domain Value Maps at Runtime
48.4.1
How to Save Domain Value Maps at Runtime
48.5
Committing Changes at Runtime
48.5.1
How to Commit Changes at Runtime
48.6
Detecting Conflicts
49
Working with Cross References
49.1
Introduction to Cross References
49.2
Introduction to Cross Reference Tables
49.3
Oracle Data Integrator Support for Cross Referencing
49.4
Creating and Modifying Cross Reference Tables
49.4.1
How to Create Cross Reference Metadata
49.4.2
What Happens When You Create a Cross Reference
49.4.3
How to Create Custom Database Tables
49.4.4
How to Add an End System to a Cross Reference Table
49.5
Populating Cross Reference Tables
49.5.1
About the xref:populateXRefRow Function
49.5.2
About the xref:populateLookupXRefRow Function
49.5.3
About the xref:populateXRefRow1M Function
49.5.4
How to Populate a Column of a Cross Reference Table
49.6
Looking Up Cross Reference Tables
49.6.1
About the xref:lookupXRef Function
49.6.2
About the xref:lookupXRef1M Function
49.6.3
About the xref:lookupPopulatedColumns Function
49.6.4
How to Look Up a Cross Reference Table for a Value
49.7
Deleting a Cross Reference Table Value
49.7.1
How to Delete a Cross Reference Table Value
49.8
Creating and Running the Cross Reference Use Case
49.8.1
How to Create the Use Case
49.8.1.1
Task 1: How to Configure the Oracle Database and Database Adapter
49.8.1.2
Task 2: How to Create an Oracle JDeveloper Application and a Project
49.8.1.3
Task 3: How to Create a Cross Reference
49.8.1.4
Task 4: How to Create a Database Adapter Service
49.8.1.5
Task 5: How to Create EBS and SBL External References
49.8.1.6
Task 6: How to Create the Logger File Adapter External Reference
49.8.1.7
Task 7: How to Create an Oracle Mediator Service Component
49.8.1.8
Task 8: How to Specify Routing Rules for an Oracle Mediator Service Component
49.8.1.9
Task 9: How to Specify Routing Rules for the Common Oracle Mediator
49.8.1.10
Task 10: How to Configure an Application Server Connection
49.8.1.11
Task 11: How to Deploy the Composite Application
49.8.2
How to Run and Monitor the XrefCustApp Application
49.9
Creating and Running Cross Reference for 1M Functions
49.9.1
How to Create the Use Case
49.9.1.1
Task 1: How to Configure the Oracle Database and Database Adapter
49.9.1.2
Task 2: How to Create an Oracle JDeveloper Application and a Project
49.9.1.3
Task 3: How to Create a Cross Reference
49.9.1.4
Task 4: How to Create a Database Adapter Service
49.9.1.5
Task 5: How to Create an EBS External Reference
49.9.1.6
Task 6: How to Create a Logger File Adapter External Reference
49.9.1.7
Task 7: How to Create an Oracle Mediator Service Component
49.9.1.8
Task 8: How to Specify Routing Rules for an Oracle Mediator Component
49.9.1.9
Task 9: How to Specify Routing Rules for the Common Oracle Mediator
49.9.1.10
Task 10: How to Configure an Application Server Connection
49.9.1.11
Task 11: How to Deploy the Composite Application
50
Defining Composite Sensors
50.1
Introduction to Composite Sensors
50.1.1
Restrictions on Use of Composite Sensors
50.2
Adding Composite Sensors
50.2.1
How to Add Composite Sensors
50.2.1.1
How to Add a Variable
50.2.1.2
How to Add an Expression
50.2.1.3
How to Add a Property
50.2.2
What You May Need to Know About Duplicate Composite Sensor Names
50.3
Monitoring Composite Sensor Data During Runtime
51
Using Two-Layer Business Process Management (BPM)
51.1
Introduction to Two-Layer Business Process Management
51.2
Creating a Phase Activity
51.2.1
How to Create a Phase Activity
51.2.2
What Happens When You Create a Phase Activity
51.2.3
What Happens at Runtime When You Create a Phase Activity
51.2.4
What You May Need to Know About Creating a Phase Activity
51.3
Creating the Dynamic Routing Decision Table
51.3.1
How to Create the Dynamic Routing Decision Table
51.3.2
What Happens When You Create the Dynamic Routing Decision Table
51.4
Use Case: Two-Layer BPM
51.4.1
Designing the SOA Composite
51.4.2
Creating a Phase Activity
51.4.3
Creating and Editing the Dynamic Routing Decision Table
51.4.4
Adding Assign Activities to the BPEL Process Model
51.4.5
Deploying and Testing the Sample
52
Integrating the Spring Framework in SOA Composite Applications
52.1
Introduction to the Spring Service Component
52.2
Integration of Java and WSDL-Based Components in the Same SOA Composite Application
52.2.1
Java and WSDL-Based Integration Example
52.2.2
Using Callbacks with the Spring Framework
52.3
Creating a Spring Service Component in Oracle JDeveloper
52.3.1
How to Create a Spring Service Component in Oracle JDeveloper
52.3.2
What You May Need to Know About Java Class Errors During Java-to-WSDL Conversions
52.4
Defining Custom Spring Beans Through a Global Spring Context
52.4.1
How to Define Custom Spring Beans Through a Global Spring Context
52.5
Using the Predefined Spring Beans
52.5.1
IHeaderHelperBean.java Interface for headerHelperBean
52.5.2
IInstanceHelperBean.java Interface for instancerHelperBean
52.5.3
ILoggerBean.java Interface for loggerBean
52.5.4
How to Reference Predefined Spring Beans in the Spring Context File
52.6
Spring Service Component Integration in the Fusion Order Demo
52.6.1
How to Use EJBs with Java Vector Type Parameters
52.7
JAXB and OXM Support
52.7.1
Extended Mapping Files
52.8
Configuring Groovy and Aspectj Classes with the Spring Service Component
52.9
Troubleshooting Spring Errors
Part X Using Oracle Business Activity Monitoring
53
Integrating Oracle BAM with SOA Composite Applications
53.1
Introduction to Integrating Oracle BAM with SOA Composite Applications
53.2
Configuring Oracle BAM Adapter
53.3
Using Oracle BAM Monitor Express With BPEL Processes
53.3.1
How to Access BPEL Designer Monitor View
53.3.2
How to Configure Activity Monitors
53.3.3
How To Create BPEL Process Monitoring Objects
53.3.4
How to Configure Counters
53.3.5
How to Configure Intervals
53.3.6
How to Configure Business Indicators
53.3.7
How to Add Existing Monitoring Objects to Activities
53.3.8
How To Configure BPEL Process Monitors for Deployment
53.3.9
What You Need to Know About Using the Monitor Express Dashboard
53.3.10
What You Need To Know About Monitor Express Data Objects
53.3.10.1
Understanding the COMPONENT Data Object
53.3.10.2
Understanding the COUNTER Data Object
53.3.10.3
Understanding the INTERVAL Data Object
53.3.10.4
Understanding Business Indicator Data Objects
53.3.10.5
Troubleshooting
53.4
Creating a Design Time Connection to an Oracle BAM Server
53.4.1
How to Create a Connection to an Oracle BAM Server
53.5
Using Oracle BAM Adapter in a SOA Composite Application
53.5.1
How to Use Oracle BAM Adapter in a SOA Composite Application
53.6
Using Oracle BAM Adapter in a BPEL Process
53.6.1
How to Use Oracle BAM Adapter in a BPEL Process
53.7
Integrating BPEL Sensors Using Oracle BAM Sensor Action
53.7.1
How to Create a Sensor
53.7.2
How to Create an Oracle BAM Sensor Action
53.8
Integrating SOA Applications and Oracle BAM Using Enterprise Message Resources
54
Using Oracle BAM Data Control
54.1
Introduction to Oracle BAM Data Control
54.2
Creating Projects That Can Use Oracle BAM Data Controls
54.3
Creating Oracle BAM Server Connections
54.3.1
How to Modify Oracle BAM Data Control Connections to Oracle BAM Servers
54.3.1.1
How to Associate a BAM Data Control with a New Oracle BAM Connection
54.4
Exposing Oracle BAM with Oracle ADF Data Controls
54.4.1
How to Create Oracle BAM Data Controls
54.4.2
What Happens in Your Project When You Create an Oracle BAM Data Control
54.4.2.1
How an Oracle BAM Data Control Appears in the Data Controls Panel
54.5
Creating Oracle BAM Data Control Queries
54.5.1
How to Choose a Query Type
54.5.2
How to Create Parameters
54.5.3
How to Pass Values to Parameters
54.5.4
How to Create Calculated Fields
54.5.4.1
Creating Groups in Calculated Fields
54.5.5
How to Select, Organize, and Sort Fields
54.5.6
How to Create Filters
54.5.6.1
How to Create Filter Headers
54.5.6.2
How to Create Filter Entries
54.5.6.3
Entering Comparison Values
54.5.6.4
Using Active Now
54.5.7
How to Select and Organize Groups
54.5.7.1
How to Configure Time Groups and Time Series
54.5.8
How to Create Aggregates
54.5.9
How to Modify the Query
54.6
Using Oracle BAM Data Controls in ADF Pages
54.6.1
How to Use an Oracle BAM Data Control in a JSF Page
54.7
Deploying Applications With Oracle BAM Data Controls
54.7.1
How to Deploy to Oracle WebLogic Server in Development Mode
54.7.2
How to Deploy to a Production Mode Oracle WebLogic Server
55
Defining and Managing Oracle BAM Data Objects
55.1
Introduction to Oracle BAM Data Objects
55.2
Defining Data Objects
55.2.1
How to Define a Data Object
55.2.2
How to Add Columns to a Data Object
55.2.3
How to Add Lookup Columns to a Data Object
55.2.4
How to Add Calculated Columns to a Data Object
55.2.5
How to Add Time Stamp Columns to a Data Object
55.2.6
What You May Need to Know About System Data Objects
55.2.7
What You May Need to Know About Oracle Data Integrator Data Objects
55.3
Creating Permissions on Data Objects
55.3.1
How to Create Permissions on a Data Object
55.3.2
How to Add a Group of Users
55.3.3
How to Copy Permissions from Other Data Objects
55.4
Viewing Existing Data Objects
55.4.1
How to View Data Object General Information
55.4.2
How to View Data Object Layouts
55.4.3
How to View Data Object Contents
55.5
Using Data Object Folders
55.5.1
How to Create Folders
55.5.2
How to Open Folders
55.5.3
How to Set Folder Permissions
55.5.4
How to Move Folders
55.5.5
How to Rename Folders
55.5.6
How to Delete Folders
55.6
Creating Security Filters
55.6.1
How to Create a Security Filter
55.6.2
How to Copy Security Filters from Other Data Objects
55.7
Creating Dimensions
55.7.1
How to Create a Dimension
55.7.2
How to Create a Time Dimension
55.8
Renaming and Moving Data Objects
55.8.1
How to Rename a Data Object
55.8.2
How to Move a Data Object
55.9
Creating Indexes
55.9.1
How to Create an Index
55.10
Clearing Data Objects
55.10.1
How to Clear a Data Object
55.11
Deleting Data Objects
55.11.1
How to Delete a Data Object
56
Creating Oracle BAM Enterprise Message Sources
56.1
Introduction to Enterprise Message Sources
56.2
Creating Enterprise Message Sources
56.2.1
How to Create an Enterprise Message Source
56.2.2
How to Configure DateTime Specification
56.2.3
How to Use Advanced XML Formatting
56.2.4
How to Configure EMS Error Handling
56.3
Using Enterprise Message Sources
56.3.1
How to Edit, Copy, and Delete Enterprise Message Sources
56.3.2
How to Start and Stop Enterprise Message Sources
56.3.3
How to Subscribe and Unsubscribe Enterprise Message Sources
56.3.4
How to Test Enterprise Message Sources
56.3.5
How to Refresh Enterprise Message Sources
56.3.6
How to Monitor Enterprise Message Source Metrics
56.4
Using Foreign JMS Providers
56.5
Use Case: Creating an EMS Against Oracle Streams AQ JMS Provider
56.5.1
Creating a JMS Topic in AQ-JMS
56.5.2
Creating a Data Source in Oracle WebLogic Server
56.5.3
Creating a Foreign JMS Server
56.5.4
Defining an EMS in Oracle BAM Architect
56.5.5
Inserting and Updating Records in the SQL Table
57
Using Oracle Data Integrator With Oracle BAM
57.1
What You May Need to Know About Integrating the Oracle Data Integrator (ODI) With Oracle BAM
57.1.1
Oracle BAM in an Application Server in 11
g
Release 1 (11.1.1.7.0)
57.1.2
Types of ODI Agents
57.1.3
Additional Installation Steps in Oracle BAM-ODI Integration in Release 11g
57.1.4
Tips for Using Oracle Data Integrator with Oracle BAM
57.1.5
Assumptions About Installing Oracle BAM-ODI integration
57.2
Installing the Oracle Data Integrator Integration Files
57.2.1
How to Install Oracle BAM-ODI Integration Files Using the Script
57.2.2
What Happens When You Install Oracle BAM-ODI Integration Files Using the Script
57.2.3
How to Manually Install Integration Files
57.2.4
Using the Logs
57.3
Using Oracle BAM Knowledge Modules
57.4
Creating the Oracle BAM Target
57.4.1
How to Create the Oracle BAM Target
57.5
Reverse Engineering the Oracle BAM Schema
57.6
Updating the Oracle Data Integrator External Data Source Definition
57.6.1
How to Update the Oracle Data Integrator External Data Source Definitions
57.7
Launching Oracle Data Integrator Scenarios From Oracle BAM Alerts
57.8
Running Oracle Data Integrator Agent as a Daemon or a Microsoft Windows Service With Oracle BAM Embedded
57.9
Installation Files for Integrating Oracle BAM and Oracle Data Integrator
58
Creating External Data Sources
58.1
Introduction to External Data Sources
58.2
Creating External Data Sources
58.2.1
How to Create an External Data Source
58.2.2
What You May Need to Know About Oracle Data Integrator External Data Sources
58.2.3
How to Edit an External Data Source
58.2.4
How to Delete an External Data Source
58.3
External Data Source Example
58.4
Use Cases
58.4.1
Use Case: Creating an EDS Against Oracle Business Intelligence Enterprise Edition
58.4.2
Use Case: Creating an External Data Source Against Sybase
58.4.3
Use Case: Creating an External Data Source Against Microsoft SQL Server
59
Using Oracle BAM Web Services
59.1
Introduction to Oracle BAM Web Services
59.2
Using the DataObjectOperations Web Services
59.2.1
How to Use the DataObjectOperations Web Services
59.3
Using the DataObjectDefinition Web Service
59.3.1
How to Use the DataObjectDefinition Web Service
59.4
Using the ManualRuleFire Web Service
59.4.1
How to Use the ManualRuleFire Web Service
59.5
Using the ICommand Web Service
59.5.1
How to Use the ICommand Web Service
60
Creating Oracle BAM Alerts
60.1
Introduction to Creating Alerts
60.2
Creating Alert Rules
60.2.1
How to Create an Alert Rule
60.2.2
How to Activate Alerts
60.2.3
How to Modify Alert Rules
60.2.4
How to Delete an Alert
60.2.5
What You May Need to Know About Modifying Alerts
60.3
Creating Alert Rules From Templates
60.3.1
How to Create Alert Rules From Templates
60.4
Creating Alert Rules With Messages
60.4.1
How to Create an Alert Rule With a Message
60.5
Creating Complex Alerts
60.5.1
How to Create a Dependent Rule
60.6
Using Alerts History
60.6.1
How to View the Alerts History List
60.6.2
How to Clear the Alerts History List
60.7
Launching Alerts by Invoking Web Services
60.8
Calling an External Action
60.9
Sending Alerts to External E-mail Accounts
61
Using ICommand
61.1
Introduction to ICommand
61.2
Executing ICommand
61.3
Specifying the Command and Option Syntax
61.3.1
How to Specify the Security Credentials
61.3.2
How to Specify the Command
61.3.3
How to Specify Object Names
61.3.4
How to Specify Multiple Parameter Targets
61.4
Using Command-line-only Parameters
61.5
Running ICommand Remotely
Part XI Using Oracle User Messaging Service
62
Oracle User Messaging Service
62.1
Introduction to User Messaging Service
62.1.1
Components
62.1.2
Architecture
63
Sending and Receiving Messages using the User Messaging Service EJB API
63.1
Introduction to the UMS Java API
63.1.1
Creating a Java EE Application Module
63.2
Creating a UMS Client Instance
63.2.1
Creating a MessagingEJBClient Instance Using a Programmatic or Declarative Approach
63.2.2
API Reference for Class MessagingClientFactory
63.3
Sending a Message
63.3.1
Creating a Message
63.3.1.1
Creating a Plaintext Message
63.3.1.2
Creating a Multipart/Alternative Message (with Text/Plain and Text/HTML Parts)
63.3.1.3
Creating Delivery Channel-Specific Payloads in a Single Message for Recipients with Different Delivery Types
63.3.2
API Reference for Class MessageFactory
63.3.3
API Reference for Interface Message
63.3.4
API Reference for Enum DeliveryType
63.3.5
Addressing a Message
63.3.5.1
Types of Addresses
63.3.5.2
Creating Address Objects
63.3.5.3
Creating a Recipient with a Failover Address
63.3.5.4
API Reference for Class AddressFactory
63.3.5.5
API Reference for Interface Address
63.3.6
Retrieving Message Status
63.3.6.1
Synchronous Retrieval of Message Status
63.3.6.2
Asynchronous Notification of Message Status
63.4
Receiving a Message
63.4.1
Registering an Access Point
63.4.2
Synchronous Receiving
63.4.3
Asynchronous Receiving
63.4.4
Message Filtering
63.5
Using the UMS Enterprise JavaBeans Client API to Build a Client Application
63.5.1
Overview of Development
63.5.2
Configuring the Email Driver
63.5.3
Using JDeveloper 11g to Build the Application
63.5.3.1
Opening the Project
63.5.4
Deploying the Application
63.5.5
Testing the Application
63.6
Using the UMS Enterprise JavaBeans Client API to Build a Client Echo Application
63.6.1
Overview of Development
63.6.2
Configuring the Email Driver
63.6.3
Using JDeveloper 11g to Build the Application
63.6.3.1
Opening the Project
63.6.4
Deploying the Application
63.6.5
Testing the Application
63.7
Creating a New Application Server Connection
64
Sending and Receiving Messages using the User Messaging Service Java API
64.1
Introduction to the UMS Java API
64.2
Creating a UMS Client Instance and Specifying Runtime Parameters
64.2.1
API Reference for Class MessagingClientFactory
64.3
Sending a Message
64.3.1
Creating a Message
64.3.1.1
Creating a Plaintext Message
64.3.1.2
Creating a Multipart/Alternative Message (with Text/Plain and Text/HTML Parts)
64.3.1.3
Creating Delivery Channel-Specific Payloads in a Single Message for Recipients with Different Delivery Types
64.3.2
API Reference for Class MessagingFactory
64.3.3
API Reference for Interface Message
64.3.4
API Reference for Enum DeliveryType
64.3.5
Addressing a Message
64.3.5.1
Types of Addresses
64.3.5.2
Creating Address Objects
64.3.5.3
Creating a Recipient with a Failover Address
64.3.5.4
API Reference for Class MessagingFactory
64.3.5.5
API Reference for Interface Address
64.3.6
User Preference Based Messaging
64.4
Retrieving Message Status
64.4.1
Synchronous Retrieval of Message Status
64.4.2
Asynchronous Receiving of Message Status
64.4.2.1
Creating a Listener Programmatically
64.4.2.2
Default Status Listener
64.4.2.3
Per Message Status Listener
64.5
Receiving a Message
64.5.1
Registering an Access Point
64.5.2
Synchronous Receiving
64.5.3
Asynchronous Receiving
64.5.3.1
Creating a Listener Programmatically
64.5.3.2
Default Message Listener
64.5.3.3
Per Access Point Message Listener
64.5.4
Message Filtering
64.6
Configuring for a Cluster Environment
64.7
Configuring Security
64.8
Threading Model
64.8.1
Listener Threading
64.9
Using the UMS Client API to Build a Client Application
64.9.1
Overview of Development
64.9.2
Configuring the Email Driver
64.9.3
Using JDeveloper 11g to Build the Application
64.9.3.1
Opening the Project
64.9.4
Deploying the Application
64.9.5
Testing the Application
64.10
Using the UMS Client API to Build a Client Echo Application
64.10.1
Overview of Development
64.10.2
Configuring the Email Driver
64.10.3
Using JDeveloper 11g to Build the Application
64.10.3.1
Opening the Project
64.10.4
Deploying the Application
64.10.5
Testing the Application
64.11
Creating a New Application Server Connection
65
Sending and Receiving Messages using the User Messaging Service Web Service API
65.1
Introduction to the UMS Web Service API
65.2
Creating a UMS Client Instance and Specifying Runtime Parameters
65.3
Sending a Message
65.3.1
Creating a Message
65.3.1.1
Creating a Plaintext Message
65.3.1.2
Creating a Multipart/Mixed Message (with Text and Binary Parts)
65.3.1.3
Creating a Multipart/Alternative Message (with Text/Plain and Text/HTML Parts)
65.3.1.4
Creating Delivery Channel-Specific Payloads in a Single Message for Recipients with Different Delivery Types
65.3.2
API Reference for Interface Message
65.3.3
API Reference for Enum DeliveryType
65.3.4
Addressing a Message
65.3.4.1
Types of Addresses
65.3.4.2
Creating Address Objects
65.3.4.3
Creating a Recipient with a Failover Address
65.3.4.4
Recipient Types
65.3.4.5
API Reference for Class MessagingFactory
65.3.4.6
API Reference for Interface Address
65.3.5
User Preference Based Messaging
65.4
Retrieving Message Status
65.4.1
Synchronous Retrieval of Message Status
65.4.2
Asynchronous Receiving of Message Status
65.4.2.1
Creating a Listener Programmatically
65.4.2.2
Publish the Callback Service
65.4.2.3
Stop a Dynamically Published Endpoint
65.4.2.4
Registration
65.5
Receiving a Message
65.5.1
Registering an Access Point
65.5.2
Synchronous Receiving
65.5.3
Asynchronous Receiving
65.5.3.1
Creating a Listener Programmatically
65.5.3.2
Default Message Listener
65.5.3.3
Per Access Point Message Listener
65.5.4
Message Filtering
65.6
Configuring for a Cluster Environment
65.7
Configuring Security
65.7.1
Client and Server Security
65.7.2
Listener/Callback Security
65.8
Threading Model
65.9
Sample Chat Application with Web Services APIs
65.9.1
Overview
65.9.1.1
Provided Files
65.9.2
Running the Pre-Built Sample
65.9.3
Testing the Sample
65.10
Creating a New Application Server Connection
66
Parlay X Web Services Multimedia Messaging API
66.1
Introduction to Parlay X Messaging Operations
66.2
Send Message Interface
66.2.1
sendMessage Operation
66.2.2
getMessageDeliveryStatus Operation
66.3
Receive Message Interface
66.3.1
getReceivedMessages Operation
66.3.2
getMessage Operation
66.3.3
getMessageURIs Operation
66.4
Oracle Extension to Parlay X Messaging
66.4.1
ReceiveMessageManager Interface
66.4.1.1
startReceiveMessage Operation
66.4.1.2
stopReceiveMessage Operation
66.5
Parlay X Messaging Client API and Client Proxy Packages
66.6
Sample Chat Application with Parlay X APIs
66.6.1
Overview
66.6.1.1
Provided Files
66.6.2
Running the Pre-Built Sample
66.6.3
Testing the Sample
66.6.4
Creating a New Application Server Connection
67
User Messaging Preferences
67.1
Introduction to User Messaging Preferences
67.1.1
Terminology
67.1.2
Configuration of Notification Delivery Preferences
67.1.3
Delivery Preference Rules
67.1.3.1
Data Types
67.1.3.2
System Terms
67.1.3.3
Business Terms
67.1.4
Rule Actions
67.2
How to Manage Messaging Channels
67.2.1
Creating a Channel
67.2.2
Editing a Channel
67.2.3
Deleting a Channel
67.2.4
Setting a Default Channel
67.3
Creating Contact Rules using Filters
67.3.1
Creating Filters
67.3.2
Editing a Filter
67.3.3
Deleting a Filter
67.4
Configuring Settings
Part XII Appendices
A
BPEL Process Activities and Services
A.1
Introduction to Activities and Components
A.2
Introduction to BPEL 1.1 and 2.0 Activities
A.2.1
Tabs Common to Many Activities
A.2.1.1
Annotations Tab
A.2.1.2
Assertions Tab
A.2.1.3
Correlations Tab
A.2.1.4
Documentation Tab
A.2.1.5
Headers Tab
A.2.1.6
Properties Tab
A.2.1.7
Skip Condition Tab
A.2.1.8
Source and Targets Tabs
A.2.1.9
Timeout Tab
A.2.2
Copying and Pasting Activities in BPEL Projects
A.2.3
Assign Activity
A.2.4
Assert Activity
A.2.5
Bind Entity Activity
A.2.6
Compensate Activity
A.2.7
CompensateScope Activity
A.2.8
Create Entity Activity
A.2.9
Dehydrate Activity
A.2.10
Email Activity
A.2.11
Empty Activity
A.2.12
Exit Activity
A.2.13
Flow Activity
A.2.14
FlowN Activity
A.2.15
forEach Activity
A.2.16
If Activity
A.2.17
IM Activity
A.2.18
Invoke Activity
A.2.19
Java Embedding Activity
A.2.20
Partner Link Activity
A.2.21
Phase Activity
A.2.22
Pick Activity
A.2.23
Receive Activity
A.2.24
Receive Signal Activity
A.2.25
Remove Entity Activity
A.2.26
RepeatUntil Activity
A.2.27
Replay Activity
A.2.28
Reply Activity
A.2.29
Rethrow Activity
A.2.30
Scope Activity
A.2.31
Sequence Activity
A.2.32
Signal Activity
A.2.33
SMS Activity
A.2.34
Switch Activity
A.2.35
Terminate Activity
A.2.36
Throw Activity
A.2.37
Transform Activity
A.2.38
User Notification Activity
A.2.39
Validate Activity
A.2.40
Voice Activity
A.2.41
Wait Activity
A.2.42
While Activity
A.3
Introduction to BPEL Services
A.4
Publishing and Browsing the Oracle Service Registry
A.4.1
How to Publish a Business Service
A.4.2
How to Create a Connection to the Registry
A.4.3
How to Configure a SOA Project to Invoke a Service from the Registry
A.4.3.1
Dynamically Resolving the SOAP Endpoint Location
A.4.3.2
Dynamically Resolving the WSDL Endpoint Location
A.4.3.3
Resolving Endpoints
A.4.4
How To Configure the Inquiry URL, UDDI Service Key, and Endpoint Address for Runtime
A.4.4.1
Changing Endpoint Locations in the Registry Control
A.4.4.2
Publishing WSDLs from Multiple SOA Partitions
A.4.5
How to Publish WSDLs to UDDI for Multiple Partitions
A.5
Providing Design-time Governance with the Oracle Enterprise Repository
A.6
Validating When Loading a Process Diagram
B
XPath Extension Functions
B.1
SOA XPath Extension Functions
B.1.1
Database Functions
B.1.1.1
lookup-table
B.1.1.2
query-database
B.1.1.3
sequence-next-val
B.1.2
Date Functions
B.1.2.1
add-dayTimeDuration-to-dateTime
B.1.2.2
current-date
B.1.2.3
current-dateTime
B.1.2.4
current-time
B.1.2.5
day-from-dateTime
B.1.2.6
format-dateTime
B.1.2.7
hours-from-dateTime
B.1.2.8
implicit-timezone
B.1.2.9
minutes-from-dateTime
B.1.2.10
month-from-dateTime
B.1.2.11
seconds-from-dateTime
B.1.2.12
subtract-dayTimeDuration-from-dateTime
B.1.2.13
timezone-from-dateTime
B.1.2.14
year-from-dateTime
B.1.3
Mathematical Functions
B.1.3.1
abs
B.1.4
String Functions
B.1.4.1
compare
B.1.4.2
compare-ignore-case
B.1.4.3
create-delimited-string
B.1.4.4
ends-with
B.1.4.5
format-string
B.1.4.6
get-content-as-string
B.1.4.7
get-content-from-file-function
B.1.4.8
get-localized-string
B.1.4.9
index-within-string
B.1.4.10
last-index-within-string
B.1.4.11
left-trim
B.1.4.12
lower-case
B.1.4.13
matches
B.1.4.14
right-trim
B.1.4.15
upper-case
B.2
BPEL XPath Extension Functions
B.2.1
addQuotes
B.2.2
authenticate
B.2.3
appendToList
B.2.4
copyList
B.2.5
countNodes
B.2.6
doc
B.2.7
doStreamingTranslate
B.2.8
doTranslateFromNative
B.2.9
doTranslateToNative
B.2.10
doXSLTransform
B.2.11
doXSLTransformForDoc
B.2.12
formatDate
B.2.13
generateGUID
B.2.14
getApplicationName
B.2.15
getAttachmentContent
B.2.16
getComponentName
B.2.17
getComponentInstanceID
B.2.18
getCompositeName
B.2.19
getCompositeInstanceID
B.2.20
getCompositeURL
B.2.21
getContentAsString
B.2.22
getConversationId
B.2.23
getCreator
B.2.24
getCurrentDate
B.2.25
getCurrentDateTime
B.2.26
getCurrentTime
B.2.27
getECID
B.2.28
getElement
B.2.29
getFaultAsString
B.2.30
getFaultName
B.2.31
getGroupIdsFromGroupAlias
B.2.32
getInstanceId
B.2.33
getNodeValue
B.2.34
getNodes
B.2.35
getOwnerDocument
B.2.36
getParentComponentInstanceID
B.2.37
getPreference
B.2.38
getProcessId
B.2.39
getProcessOwnerId
B.2.40
getProcessURL
B.2.41
getProcessVersion
B.2.42
getUserAliasId
B.2.43
getUserIdsFromGroupAlias
B.2.44
setCompositeInstanceTitle
B.2.45
instanceOf
B.2.46
integer
B.2.47
listUsers
B.2.48
lookupUser
B.2.49
parseEscapedXML
B.2.50
parseXML
B.2.51
processXQuery
B.2.52
processXSLT
B.2.53
readBinaryFromFile
B.2.54
readFile
B.2.55
search
B.2.56
writeBinaryToFile
B.2.57
BPEL Extension Functions in BPEL 1.1 and BPEL 2.0
B.2.57.1
getLinkStatus
B.2.57.2
getVariableData
B.2.57.3
getVariableProperty (For BPEL 1.1)
B.2.57.4
getVariableProperty (For BPEL 2.0)
B.2.58
Utility Functions
B.2.58.1
batchProcessActive
B.2.58.2
batchProcessCompleted
B.2.58.3
format
B.2.58.4
genEmptyElem
B.2.58.5
getChildElement
B.2.58.6
getMessage
B.2.58.7
max-value-among-nodeset
B.2.58.8
min-value-among-nodeset
B.2.58.9
square-root
B.3
Oracle Mediator XPath Extension Functions
B.3.1
doStreamingTranslate
B.3.2
doTranslateFromNative
B.3.3
doTranslateToNative
B.3.4
getAttachmentContent
B.3.5
getComponentInstanceID
B.3.6
getComponentName
B.3.7
getCompositeInstanceID
B.3.8
getCompositeName
B.3.9
getHeader
B.3.10
getECID
B.3.11
getParentComponentInstanceID
B.3.12
readBinaryFromFile
B.3.13
setCompositeInstanceTitle
B.4
Advanced Functions
B.4.1
create-nodeset-from-delimited-string
B.4.2
generate-guid
B.4.3
lookupPopulatedColumns
B.4.4
lookupValue
B.4.5
lookupValue1M
B.4.6
lookupXRef
B.4.7
lookupXRef1M
B.4.8
lookup-xml
B.4.9
markForDelete
B.4.10
populateXRefRow
B.4.11
populateXRefRow1M
B.5
Workflow Service Functions
B.5.1
clearTaskAssignees
B.5.2
createWordMLDocument
B.5.3
getNotificationProperty
B.5.4
getNumberOfTaskApprovals
B.5.5
getPreviousTaskApprover
B.5.6
getTaskAttachmentByIndex
B.5.7
getTaskAttachmentByName
B.5.8
getTaskAttachmentContents
B.5.9
getTaskAttachmentsCount
B.5.10
getTaskResourceBundleString
B.5.11
wfDynamicGroupAssign
B.5.12
wfDynamicUserAssign
B.5.13
Identity Service Functions
B.5.13.1
getDefaultRealmName
B.5.13.2
getGroupProperty
B.5.13.3
getManager
B.5.13.4
getReportees
B.5.13.5
getSupportedRealmNames
B.5.13.6
getUserProperty
B.5.13.7
getUserRoles
B.5.13.8
getusersinapprole
B.5.13.9
getUsersInGroup
B.5.13.10
isUserInRole
B.5.13.11
lookupGroup
B.5.13.12
lookupUser
B.6
Building XPath Expressions in the Expression Builder in Oracle JDeveloper
B.6.1
How to Use the Expression Builder
B.6.2
Introduction to the XPath Building Assistant
B.6.3
How to Use the XPath Building Assistant
B.6.4
Using the XPath Building Assistant in the XSLT Mapper
B.6.5
Function Parameter Tool Tips
B.6.6
Syntactic and Semantic Validation
B.6.7
Creating Expressions with Free Form Text and XPath Expressions
B.6.8
Using Double Slashes for Directory Paths in XPath Functions on Windows Can Cause Errors
B.7
Creating User-Defined XPath Extension Functions
B.7.1
How to Implement User-Defined XPath Extension Functions
B.7.1.1
How to Implement Functions for the XSLT Mapper
B.7.1.2
How to Implement Functions for All Other Components
B.7.2
How to Configure User-Defined XPath Extension Functions
B.7.3
How to Deploy User-Defined Functions to Runtime
C
Deployment Descriptor Properties
C.1
Introduction to Deployment Descriptor Properties
C.1.1
How to Define Deployment Descriptor Properties in the Property Inspector
C.1.2
How to Get the Value of a Preference within a BPEL Process
C.2
Deprecated 10.1.3 Properties
D
Understanding Sensor Public Views and the Sensor Actions XSD
D.1
Introduction to Sensor Public Views and the Sensor Actions XSD File
D.2
Sensor Public Views
D.2.1
BPM Schema
D.2.1.1
BPEL_PROCESS_INSTANCES
D.2.1.2
BPEL_ACTIVITY_SENSOR_VALUES
D.2.1.3
BPEL_FAULT_SENSOR_VALUES
D.2.1.4
BPEL_VARIABLE_SENSOR_VALUES
D.3
Sensor Actions XSD File
E
Oracle BAM Web Services Operations
E.1
DataObjectOperations10131
E.1.1
Batch
E.1.1.1
Request Message
E.1.2
Delete
E.1.2.1
Request Message
E.1.3
Insert
E.1.3.1
Request Message
E.1.4
Update
E.1.4.1
Request Message
E.1.5
Upsert
E.1.5.1
Request Message
E.2
DataObjectOperationsByName
E.2.1
Delete
E.2.1.1
Request Message
E.2.2
Get
E.2.2.1
Request Message
E.2.3
Insert
E.2.3.1
Request Message
E.2.4
Update
E.2.4.1
Request Message
E.2.5
Upsert
E.2.5.1
Request Message
E.3
DataObjectOperationsByID
E.3.1
Batch
E.3.1.1
Request Message
E.3.2
Delete
E.3.2.1
Request Message
E.3.3
Insert
E.3.3.1
Request Message
E.3.4
Update
E.3.4.1
Request Message
E.3.5
Upsert
E.3.5.1
Request Message
E.4
DataObjectDefinition Operations
E.4.1
Create
E.4.1.1
Request Message
E.4.1.2
Response Message
E.4.2
Delete
E.4.2.1
Request Message
E.4.2.2
Response Message
E.4.3
Get
E.4.3.1
Request Message
E.4.3.2
Response Message
E.4.4
Update
E.4.4.1
Request Message
E.4.4.2
Response Message
E.5
ManualRuleFire Operations
E.5.1
FireRuleByName
E.5.1.1
Request Message
E.5.1.2
Response Message
F
Oracle BAM Alert Rule Options
F.1
Events
F.1.1
In a specific amount of time
F.1.2
At a specific time today
F.1.3
On a certain day at a specific time
F.1.4
Every interval between two times
F.1.5
Every date interval starting on certain date at a specific time
F.1.6
When a report changes
F.1.7
When a data field changes in data object
F.1.8
When a data field in a report meets specified conditions
F.1.9
When a data field in a data object meets specified conditions
F.1.10
When this rule is launched
F.2
Conditions
F.2.1
If it is between two times
F.2.2
If It is between two days
F.2.3
If it is a particular day of the week
F.3
Actions
F.3.1
Send a report via email
F.3.2
Send a message via email
F.3.3
Send a report via email and escalate to another user after a specific amount of time
F.3.4
Send a parameterized message
F.3.5
Send a parameterized message for every matching row in a data object
F.3.6
Launch a rule
F.3.7
Launch rule if an action fails
F.3.8
Delete rows from a Data Object
F.3.9
Call a Web Service
F.3.9.1
How to Use Call a Web Service: An Example
F.3.10
Run an Oracle Data Integrator Scenario
F.3.11
Call an External Action
F.4
Frequency Constraint
G
Oracle BAM ICommand Operations and File Formats
G.1
Summary of Individual Operations
G.2
Detailed Operation Descriptions
G.2.1
Clear
G.2.2
Delete
G.2.3
Export
G.2.4
Import
G.2.5
Rename
G.3
Format of Command File
G.3.1
Inline Content
G.3.2
Command IDs
G.3.3
Continue On Error
G.4
Format of Log File
G.5
Sample Export File
G.6
Regular Expressions
H
Normalized Message Properties
H.1
Introduction to Normalized Messages
H.2
Oracle BPEL Process Manager Properties
H.3
Oracle Web Services Addressing Properties
H.4
Manipulating Normalized Message Properties with bpelx Extensions
H.4.1
BPEL 1.1 bpelx Extensions Syntax
H.4.2
BPEL 2.0 bpelx Extensions Syntax
I
Interfaces Implemented By Rules Dictionary Editor Task Flow
I.1
The MetadataDetails Interface
I.1.1
The getDocument Method
I.1.2
The getRelatedDocument Method
I.1.3
The setDocument Method
I.2
The NLSPreferences Interface
J
Oracle User Messaging Service Applications
J.1
Installing and Configuring SOA and User Messaging Service
J.1.1
Updating Addresses in Your LDAP User Profile
J.1.1.1
Installing
J.1.1.2
Connecting
J.1.1.3
Setting User Messaging Device Addresses in LDAP
J.2
Sending Message to User Specified Channels
J.2.1
Overview of the SendMessage Application
J.2.1.1
Provided Files
J.2.2
Building the Sample
J.2.3
Creating a New Application Server Connection
J.2.4
Deploying the Project
J.2.5
Configuring User Messaging Preferences
J.2.6
Testing the Sample
J.2.6.1
Verifying the Execution of Sending the Email
J.3
Send Email with Attachments
J.3.1
Overview of SendEmailWithAttachment Application
J.3.1.1
Provided Files
J.3.2
Running the Pre-Built Sample
J.3.3
Testing the Sample
J.3.3.1
Verifying the Execution
J.3.4
Building the Sample
J.3.4.1
Sending Text Content with base64 Encoding
K
Oracle SOA Suite Properties Road Map
K.1
Oracle BPEL Process Manager Deployment Descriptor Properties
K.2
Normalized Message Header Properties
K.2.1
Oracle JCA Adapter Message Header Properties
K.2.2
Oracle BPEL Process Manager and Oracle Web Services Addressing Message Header Properties
K.2.3
Oracle B2B Message Header Properties
K.3
SOA Composite Application Properties
K.4
Fault Policy and Adapter Rejected Message Properties
K.5
Oracle B2B System Properties
K.6
Oracle Enterprise Manager Fusion Middleware Control Property Pages
K.6.1
SOA Infrastructure Properties
K.6.2
Oracle BPEL Process Manager
K.6.3
Human Workflow Notification and Task Service
K.6.4
Oracle Mediator
K.6.5
Cross References
K.6.6
Oracle B2B
K.6.7
Service and Reference Binding Component Properties
K.7
System MBean Browser Properties
K.7.1
SOA Infrastructure Properties
K.7.2
Oracle BPEL Process Manager Properties
K.7.3
Oracle Mediator Properties
K.7.4
Human Workflow Notification and Task Service Properties
K.7.5
Oracle Service Registry WSDL URL Caching Configuration
Index
Scripting on this page enhances content navigation, but does not change the content in any way.