| <!-- |
| ~ Licensed to the Apache Software Foundation (ASF) under one |
| ~ or more contributor license agreements. See the NOTICE file |
| ~ distributed with this work for additional information |
| ~ regarding copyright ownership. The ASF licenses this file |
| ~ to you under the Apache License, Version 2.0 (the |
| ~ "License"); you may not use this file except in compliance |
| ~ with the License. You may obtain a copy of the License at |
| ~ |
| ~ http://www.apache.org/licenses/LICENSE-2.0 |
| ~ |
| ~ Unless required by applicable law or agreed to in writing, |
| ~ software distributed under the License is distributed on an |
| ~ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| ~ KIND, either express or implied. See the License for the |
| ~ specific language governing permissions and limitations |
| ~ under the License. |
| --> |
| |
| <!-- Reusable database connection pool --> |
| <definitions xmlns="http://ws.apache.org/ns/synapse"> |
| |
| <sequence name="myFaultHandler"> |
| <makefault> |
| <code value="tns:Receiver" xmlns:tns="http://www.w3.org/2003/05/soap-envelope"/> |
| <reason expression="get-property('ERROR_MESSAGE')"/> |
| </makefault> |
| |
| <property name="RESPONSE" value="true"/> |
| <header name="To" expression="get-property('ReplyTo')"/> |
| <send/> |
| <drop/> |
| </sequence> |
| |
| <sequence name="main" onError="myFaultHandler"> |
| <in> |
| <log level="custom"> |
| <property name="text" |
| value="** Looking up from the Database **"/> |
| </log> |
| <dblookup> |
| <connection> |
| <pool> |
| <dsName>lookupdb</dsName> |
| <icClass>com.sun.jndi.rmi.registry.RegistryContextFactory</icClass> |
| <url>rmi://localhost:2199</url> |
| <user>synapse</user> |
| <password>synapse</password> |
| </pool> |
| </connection> |
| <statement> |
| <sql>select * from company where name =?</sql> |
| <parameter expression="//m0:getQuote/m0:request/m0:symbol" |
| xmlns:m0="http://services.samples/xsd" type="VARCHAR"/> |
| <result name="company_id" column="id"/> |
| </statement> |
| </dblookup> |
| |
| <switch source="get-property('company_id')"> |
| <case regex="c1"> |
| <log level="custom"> |
| <property name="text" |
| expression="fn:concat('Company ID - ',get-property('company_id'))"/> |
| </log> |
| <send> |
| <endpoint> |
| <address uri="http://localhost:9000/soap/SimpleStockQuoteService"/> |
| </endpoint> |
| </send> |
| </case> |
| <case regex="c2"> |
| <log level="custom"> |
| <property name="text" |
| expression="fn:concat('Company ID - ',get-property('company_id'))"/> |
| </log> |
| <send> |
| <endpoint> |
| <address uri="http://localhost:9000/soap/SimpleStockQuoteService"/> |
| </endpoint> |
| </send> |
| </case> |
| <case regex="c3"> |
| <log level="custom"> |
| <property name="text" |
| expression="fn:concat('Company ID - ',get-property('company_id'))"/> |
| </log> |
| <send> |
| <endpoint> |
| <address uri="http://localhost:9000/soap/SimpleStockQuoteService"/> |
| </endpoint> |
| </send> |
| </case> |
| <default> |
| <log level="custom"> |
| <property name="text" value="** Unrecognized Company ID **"/> |
| </log> |
| <makefault> |
| <code value="tns:Receiver" |
| xmlns:tns="http://www.w3.org/2003/05/soap-envelope"/> |
| <reason value="** Unrecognized Company ID **"/> |
| </makefault> |
| <property name="RESPONSE" value="true"/> |
| <header name="To" action="remove"/> |
| <send/> |
| <drop/> |
| </default> |
| </switch> |
| <drop/> |
| </in> |
| |
| <out> |
| <log level="custom"> |
| <property name="text" |
| value="** Reporting to the Database **"/> |
| </log> |
| <dbreport> |
| <connection> |
| <pool> |
| <dsName>reportdb</dsName> |
| <icClass>com.sun.jndi.rmi.registry.RegistryContextFactory</icClass> |
| <url>rmi://localhost:2199</url> |
| <user>synapse</user> |
| <password>synapse</password> |
| </pool> |
| </connection> |
| <statement> |
| <sql>update company set price=? where name =?</sql> |
| <parameter expression="//m0:return/m0:last/child::text()" |
| xmlns:m0="http://services.samples/xsd" type="DOUBLE"/> |
| <parameter expression="//m0:return/m0:symbol/child::text()" |
| xmlns:m0="http://services.samples/xsd" type="VARCHAR"/> |
| </statement> |
| </dbreport> |
| <log level="custom"> |
| <property name="text" |
| value="** Looking up from the Database **"/> |
| </log> |
| <dblookup> |
| <connection> |
| <pool> |
| <dsName>reportdb</dsName> |
| <icClass>com.sun.jndi.rmi.registry.RegistryContextFactory</icClass> |
| <url>rmi://localhost:2199</url> |
| <user>synapse</user> |
| <password>synapse</password> |
| </pool> |
| </connection> |
| <statement> |
| <sql>select * from company where name =?</sql> |
| <parameter expression="//m0:return/m0:symbol/child::text()" |
| xmlns:m0="http://services.samples/xsd" type="VARCHAR"/> |
| <result name="stock_price" column="price"/> |
| </statement> |
| </dblookup> |
| <log level="custom"> |
| <property name="text" |
| expression="fn:concat('Stock price - ',get-property('stock_price'))"/> |
| </log> |
| <send/> |
| |
| </out> |
| |
| </sequence> |
| |
| </definitions> |