data:image/s3,"s3://crabby-images/74ef5/74ef5f11f20947aada41cbf4f32ce0b100751bae" alt="image image"
We have seen in previous articles how DB Adapter can be used in SOA Suite to write information to Database. SOA Suite 11g provides another method to implement Entity Services: Service Data Object (SDO).
SDO provides a unified interface to access datasource, irrespective of its type, from SOA composite. This is achieved by creating Data Services with the help of ADF Business Components. At the outset, it may sound no different from previous methods. However, the difference is that the data can be accessed with the help of an entity variable within BPEL. Data is synchronized with external updates as well. Nested objects are also supported. In addition, we can enable RMI communication instead of SOAP to improve performance.
BPEL provides three constructs for this purpose:
- ADF-BC service adapter to send and receive messages from ADF BC service.
- Create Entity and Bind Entity activities.
data:image/s3,"s3://crabby-images/83ec1/83ec150712ab5643142bea9b0342a1c5ef76c095" alt="image image"
data:image/s3,"s3://crabby-images/e4124/e41240e71c0c780bbe0c92a45df40a4c2841e954" alt="image image"
ADF-BC Service will let process bind to an existing ADF Business Component service layer. Once ADF BC service reference is successfully created, composite.xml will contain following XML fragment:
<reference name="OrderSDO"Where
ui:wsdlLocation=http://192.160.1.5:7001/OrderSDOWebServices/OrderSDOService?WSDL>
<interface.wsdl interface="http://www.orafmwschool.com/training/sdo/app/common/#wsdl.interface(OrderSDOService)"/>
<binding.adf serviceName="{http://www.orafmwschool.com/training/sdo/app/common/}OrderSDOService"
registryName="OrderSDOApplication_JBOServiceRegistry"/>
</reference>
- wsdlLocation points to webservices exposed by ADF Business Component Application.
- registryName is constructed using <ADF BC Application Name>_JBOServiceRegistry. In the above example, OrderSDOApplication is ADF application name. This key is automatically generated and is used to look up SDO through RMI.
<bpelx:createEntity name="CreateOrderEV" variable="OrderViewEV">Once entity variable is successfully created and bound to SDO, any operation performed on the entity variable will transparently invoke appropriate ADF BC service. For example, following copy activity will transparently update CreatedBy column in ORDERS table.
<bpelx:fromExpression>bpws:getVariableData(‘inputVariable’)</bpelx:fromExpression>
</bpelx:createEntity>
<bpelx:bindEntity name="BindOrderEV" variable="OrderViewEV">
<bpelx:key keyname="ns2:OrderId">bpws:getVariableData(‘inputVariable’,'parameters’,'/ns3:createOrafmwschoolOrdersView1/ns3:orafmwschoolOrdersView1/ns2:OrderId’)</bpelx:key>
</bpelx:bindEntity>
<copy>In this tutorial, we will create an OrderSample BPEL process that creates Orders and Order Items in database with the help of SDO and ADF Business Components. We’ll implement this example in two parts:
<from variable="inputVariable" part="parameters"
query="/ns3:createOrafmwschoolOrdersView1/ns3:orafmwschoolOrdersView1/ns2:CreatedBy"/>
<to variable="OrderViewEV"
query="/ns2:orafmwschoolOrdersViewSDO/ns2:CreatedBy"/>
</copy>
- Order data services using ADF Business Components. Complete jdeveloper project can be downloaded from here.
- Order BPEL process that uses Order data services through SDO entity variable.
1. Create Order data services using ADF Business Components
- Create a new schema called “FOD”. Run dataobjects.sql to create tables as shown below.
data:image/s3,"s3://crabby-images/edb7e/edb7ecf0ebd340f59f3e0bfbf4d75fdeff43b38d" alt="Data Objects Data Objects"
- Create a new generic application called “OrderSDOApplication”.
data:image/s3,"s3://crabby-images/2d7a9/2d7a933b4bee35cff9a1ce162f8dbbfaa4499115" alt="SDO Application SDO Application"
- In the next step, name the project “OrderBusinessComponents” and select “ADF Business Components” from the available project technologies.
data:image/s3,"s3://crabby-images/8e07e/8e07e19e824768ac530dbc27eda94afc661cb95b" alt="Order Business Components Project Order Business Components Project"
- Right click on “OrderBusinessComponents”, select “New” and then “Business Components from Tables” from Business Tier section.
data:image/s3,"s3://crabby-images/1c9f9/1c9f9b5ddef7c6164a6f9f062cdbc2a361e60bc1" alt="Order Business Components Project Order Business Components Project"
- Select FOD database connection in the next screen. If not already created, create a new connection to FOD schema.
data:image/s3,"s3://crabby-images/05181/05181095c96716f645b2cee49ec066e61691b150" alt="DB Connection wizard DB Connection wizard"
data:image/s3,"s3://crabby-images/5d114/5d114905126a9c7e664f86d416c6ac9fa0ee48a4" alt="DB Connection wizard DB Connection wizard"
- Click OK. From next screen, select ORAFMWSCHOOL_ORDERS, ORAFMWSCHOOL_ORDER_ITEMS tables.
data:image/s3,"s3://crabby-images/1c395/1c395a01c7e3662be5a7450dd98730175a2edd9e" alt="Entity Objects Entity Objects"
- Select both views from next screen.
data:image/s3,"s3://crabby-images/f8515/f8515f2043dd4ab81e404c31df22398a5d5f5eb3" alt="ADF BC Updateable Views ADF BC Updateable Views"
- Accept default values in “Read-Only View Objects” and click on Next.
- Specify “OrderSDO” as the name of Application Module. Click Next in subsequent screens to arrive at Summary screen and click on Finish
data:image/s3,"s3://crabby-images/9f803/9f80302e0cda7df9584cb978590bdbc359cf0bd1" alt="ADF BC Summary Screen ADF BC Summary Screen"
- This creates an Application Module, updateable view objects as well as corresponding relationships between tables.
data:image/s3,"s3://crabby-images/b627e/b627eb807d75fa48edada3b36be1452e7bf7d7cf" alt="ADF BC Summary Screen ADF BC Summary Screen"
Service Enable OrderSDO
- Double click on OrderSDO to bring up properties page.
- Select “Services Interface” option from the next screen.
data:image/s3,"s3://crabby-images/d5bf9/d5bf923b8cc01e28a0bfab6b48211411ea57b9c9" alt="SDO Service Interface SDO Service Interface"
- Click on “+” icon to create new service interface. Specify meaningful namespace.
data:image/s3,"s3://crabby-images/a2905/a290512af174b0e5b504b8ac7317323263558f13" alt="ADF Service Interface ADF Service Interface"
- Click Next twice to arrive at Step 3.
- Select OrfmwschoolOrdersView1 and OrafmwschoolOrderItemsView1. For each of these views, select all listed operations.
data:image/s3,"s3://crabby-images/5dd43/5dd43910c87cab4e2a4357c401de9bbae9c91df2" alt="ADF Service Interface ADF Service Interface"
data:image/s3,"s3://crabby-images/2d7e8/2d7e8cfd6b15d03580f41450ac4b85a211184037" alt="ADF Service Interface ADF Service Interface"
- Click Finish to generate Service Interface.
data:image/s3,"s3://crabby-images/d518b/d518bd099eb034a2da003cc95452f02ac5519a49" alt="ADF Service Interface ADF Service Interface"
- Click on Configurations tab in the above screen and double click on OrderSDOService.
data:image/s3,"s3://crabby-images/329a2/329a2bb2fb23f322e4f2a28b86eb100def2930a4" alt="ADF Service Interface ADF Service Interface"
- By default, ADF Business Components use Managed Datasource available in Weblogic Server. Name of datasource is of format java:comp/env/jdbc/<DB_Connection_Name>DS. In this example, it is “java:comp/env/jdbc/FODDS”.
- Enable direct JDBC connectivity instead of using Managed Datasource. From connection type, select “JDBC URL” and leave default values. This is only for this example purpose. In production systems, using Managed Datasource is recommended.
data:image/s3,"s3://crabby-images/9228c/9228ce1c031b4b6fb6b5b497a7f14d993efcb88c" alt="ADF BC Service DB Connection ADF BC Service DB Connection"
data:image/s3,"s3://crabby-images/bdea9/bdea9f28b66cb2991aa4dcc7f9cc0a8a54306a57" alt="ADF BC Service DB Connection ADF BC Service DB Connection"
Enable Master Detail relationship
To enable OrderSDO to process OrderItemsSDO, we need to set SERVICE_PROCESS_CHILDREN property to true in the mastser-detail association link.
- Double click on OrafmwschoolOrderItemsFk1Assoc.xml to bring up properties page. Add custom property with name: “SERVICE_PROCESS_CHILDREN” and value: “true”.
data:image/s3,"s3://crabby-images/f5434/f54349b426121e5aa2044e41fa0f3a33d9ae361f" alt="ADF BC Service Deployment ADF BC Service Deployment"
Create Deployment Profiles for Project and Application
Right click on OrderBusinessComponents project to bring up project properties page. Click on “Deployment” and then “New” to create a new deployment profile. Specify “Business Components Services Archive” for archive type and specify “OrderBCProfile” as name. Click OK.
data:image/s3,"s3://crabby-images/99fc0/99fc0a468bdc3afded49a66154fd212745f3dee0" alt="ADF BC Service Deployment ADF BC Service Deployment"
- Select Java EE Application and specify “OrderBCServices” for Webcontext root just to make the context name short. Click OK.
data:image/s3,"s3://crabby-images/9b89f/9b89f1c24b6670c211d4a6e87782417acf272901" alt="ADF BC Service Deployment ADF BC Service Deployment"
- Right click on “OrderSDOApplication” and select Application Properties. Edit “OrderBusinessComponents_OrderBCProfile (EAR File)”. Specify “OrderSDO Application” as the name of application.
data:image/s3,"s3://crabby-images/d2ff2/d2ff23a0f636bc27a5e5b584be31714e3af754a7" alt="ADF BC Service Deployment ADF BC Service Deployment"
- We can now right click on “OrderSDOApplication” and deploy Business Components to SOA Server. This would create webservices with operations we selected in previous steps. These webservices will use standard SOAP protocol. However, in order to create transactional services, we will have to enable RMI as communication protocol.
- Application name in previous step will be used later in part-2 of this article to construct RMI lookup key: OrderSDOApp_JBOServiceRegistry.
- From Application Navigator, select weblogic-application.xml as shown below.
data:image/s3,"s3://crabby-images/3224d/3224de07fa3681a3d3dd6485d4dd8ab9bbfc5288" alt="ADF BC Deployment ADF BC Deployment"
- Select Listeners tab. Add a new service listener with class name “oracle.jbo.client.svc.ADFApplicationLifecycleListener”.
data:image/s3,"s3://crabby-images/22d2b/22d2b6d8fd4539e8160e00d13a3ba417d86366bb" alt="ADF BC Deployment ADF BC Deployment"
- Right click on “OrderSDOApplication” and deploy to SOA Server.
data:image/s3,"s3://crabby-images/d1656/d1656946c2f67a25e8785026b162d45654ca02ff" alt="ADF BC Deployment ADF BC Deployment"
- JDeveloper would display successful deployment message along with URL to access web application as shown below.
data:image/s3,"s3://crabby-images/b6839/b6839202a840e4dd42df3b95cf67c57788164b8a" alt="image image"
- Access URL http://<your_server_name>:port/OrderBCServices/OrderSDOService?WSDL to confirm successful deployment.
data:image/s3,"s3://crabby-images/eca8a/eca8a293a131d3d90bf472a8047bcea67aacb52b" alt="image image"
Complete jdeveloper project can be downloaded from here..
Part-2 of this example deals with using SDO in BPEL with the help of BC Adapter and Entity Variables. Stay tuned …
Lets build Order BPEL process to consumer ADF Business Components we created in previous example through an entity variable.
- Create an SOA project and name it “OrderSDOProcess”. Select Empty Composite from next screen and click Finish.
data:image/s3,"s3://crabby-images/ae316/ae316229358de4ad14909407f69f61d2b301df31" alt="image image"
data:image/s3,"s3://crabby-images/3abc3/3abc32f5830e7cac7b3a586198dd8aaf1d746223" alt="image image"
- Make a note of OrderSDO service WSDL we created in previous step. In my case, it is http://192.168.0.5:7001/OrderBCServices/OrderSDOService?WSDL.
- Drag and drop a BPEL Process component on to components section of composite.xml. Name it “OrderSDOProcess”. Select “Base on a WSDL” as template.
data:image/s3,"s3://crabby-images/1f313/1f313fb5ac71f1c50d847fba49eaa6c0089fb8b7" alt="image image"
- Paste WSDL URL from previous step. In my case, http://192.168.0.5:7001/OrderBCServices/OrderSDOService?WSDL. OrderSDOService port type will be automatically populated. Click OK.
data:image/s3,"s3://crabby-images/38803/388032c7e114fb3d2567bcde8bbfb60f6a43c016" alt="image image"
- Double click on OrderSDOProcess in composite.xml to bring up BPEL process page.
data:image/s3,"s3://crabby-images/48c31/48c31dcb4d5b8f08bddf62c3ef890f68da4fc29e" alt="image image"
- Double click on receiveInput activity and select “createOrafmwschoolOrdersView1” as the input operation.
data:image/s3,"s3://crabby-images/cf23e/cf23ec0d4ad11a9af103c0d4e2ae6fd46dcf5808" alt="image image"
- Next to Variable section, click on “+” icon to auto generate input variable. Click OK.
data:image/s3,"s3://crabby-images/7122b/7122bd241dd8aa3de769ee933afbd316b32c5acf" alt="image image"
- Receive these steps for “replyOutput” activity to select “createOrafmwschoolOrdersView1” operation and auto-create output variable. Click OK.
data:image/s3,"s3://crabby-images/59943/59943a056a5f53d3b8ff4f1139a4de0b8d803e98" alt="image image"
- Drag and drop a ADF-BC Service adapter from BPEL Services section. Fill in values as shown below. As you may have observed, Registry key is of the form <ADF BC Application Name>_JBOServiceRegistry. In previous example, we named our ADF BC application – OrderSDOApp. Click OK to create SDO partner link.
data:image/s3,"s3://crabby-images/712e2/712e2581270fc51fafe78fe9fbb822eeac3d4b85" alt="image image"
- Let us create entity variable to use our SDO service. Drag and drop “Create Entity” activity below “receiveInput”.
data:image/s3,"s3://crabby-images/2119d/2119d8072011f5b780f8ee4b7589fc398cd3bdb6" alt="image image"
- Double click on CreateEntity_1 activity and click on Browse icon next to “Entity Variable” field.
data:image/s3,"s3://crabby-images/44106/441060ccfc339daa0a0e616e05de436c58a692ab" alt="image image"
- Click on “+” icon to create new entity variable. Name it “OrdersViewEV” and select type as “Element”. Select orafmwschoolOrdersViewSDO as element value as shown below. Click OK.
data:image/s3,"s3://crabby-images/fc5c4/fc5c46507e5ed770416d6c45307bfcd85e22b953" alt="image image"
data:image/s3,"s3://crabby-images/bf58f/bf58fa2bf20981e79f988d89f73cb4a06ba83731" alt="image image"
- Associate this entity variable with OrderSDOService partner link as shown below from next step. Click OK in next subsequent screens to go back to “Create Entity” screen.
data:image/s3,"s3://crabby-images/0f459/0f45977f7ecc62a6dfacf01b02d0285f6475e047" alt="image image"
data:image/s3,"s3://crabby-images/bb1c3/bb1c390ac81f6579743bcc24218de7fd035ba013" alt="image image"
- Select “receiveInput_createOrafmwschoolOrdersView1_InputVariable” for From element as shown below.
data:image/s3,"s3://crabby-images/1e55c/1e55c827462e41f8aab0bdb66870654de0e0f176" alt="image image"
data:image/s3,"s3://crabby-images/f5f92/f5f92346b0dd44b41a929e3a9e8c1b157d585c89" alt="image image"
- Click OK in “Create Entity” screen.
- Drag and drop “Bind Entity” activity next to “Create Entity”.
- Double click on “Bind Entity” and select OrdersViewEV as entity variable. Click OK.
data:image/s3,"s3://crabby-images/88098/880980f398723bbe340e48085b52c79ad419e7fa" alt="image image"
- Click “+” in Unique Keys section to select a unique key to bind to SDO entity variable. In our case it is going to be OrderId.
- Select OrderId from OrdersViewEV variable for Key Local Part, as shown below.
data:image/s3,"s3://crabby-images/e854a/e854a4543f8309b0fe6d14eea0cca39ff6af095d" alt="image image"
data:image/s3,"s3://crabby-images/5f549/5f5494d9ac4047b3ead91e113f70585ffdf199b6" alt="image image"
- Similarly select “OrderId” from process input variable for “Key Value” field, as shown below.
data:image/s3,"s3://crabby-images/8e7df/8e7df3d13cef758d3990651d1ce89f5eb4e02695" alt="image image"
data:image/s3,"s3://crabby-images/996f6/996f6fdb2c2b999fa81855c09791f99526b5b076" alt="image image"
- Click OK to save and close “Bind Entity” dialog.
- Drag and drop an Assign activity between “CreateEntity_1” and “BindEntity_1”. Assign OrderId from process input variable SDO entity variable as shown below. Repeat this step for the elements of OrdersView and OrderItemsView.
data:image/s3,"s3://crabby-images/78e04/78e0459f5d1dfa997db3a6dc314c75d8b4ddef18" alt="image image"
- Deploy and test the process.
No comments:
Post a Comment