Routing Based on Message Payloads¶
This example scenario uses a back-end service with two stock quote inventories (IBM and MSFT). A proxy service is configured in the Micro Integrator to use separate mediation sequences for processing request messages with different payloads.
When a stock quote request is received, the Micro Integrator will read the message payload (content) and then route the message to the relevant mediation sequence for processing. The sequence will forward the message to the relevant stock quote inventory in the backend, receive the response, process it, and return it to the client.
Synapse configuration¶
Listed below are the synapse configurations (proxy service) for implementing this scenario. See the instructions on how to build and run this example.
<?xml version="1.0" encoding="UTF-8"?>
<proxy name="ContentBasedRoutingProxy" startOnLoad="true" transports="https http" xmlns="http://ws.apache.org/ns/synapse">
<target>
<inSequence>
<!-- The content of the incoming message will be isolated -->
<!-- it is possible to assign the result of an XPath expression as well -->
<!-- Will Route the content to the appropriate destination -->
<switch source="$body//ser:getQuote/ser:request/xsd:symbol" xmlns:ser="http://services.samples" xmlns:xsd="http://services.samples/xsd">
<case regex="IBM">
<sequence key="sequence1"/>
</case>
<case regex="MSFT">
<sequence key="sequence2"/>
</case>
<default>
<log level="custom">
<property expression="fn:concat('Invalid request for symbol - ', //ser:getQuote/ser:request/xsd:symbol)" name="Error"/>
</log>
</default>
<!-- The isolated content will be filtered -->
</switch>
</inSequence>
<faultSequence/>
</target>
</proxy>
<?xml version="1.0" encoding="UTF-8"?>
<sequence xmlns="http://ws.apache.org/ns/synapse" name="sequence1">
<sequence key="send_seq"/>
<property name="messageType" value="application/json" scope="axis2"/>
<respond/>
</sequence>
<?xml version="1.0" encoding="UTF-8"?>
<sequence xmlns="http://ws.apache.org/ns/synapse" name="sequence2">
<sequence key="send_seq"/>
<property name="messageType" value="text/xml" scope="axis2"/>
<respond/>
</sequence>
<?xml version="1.0" encoding="UTF-8"?>
<sequence xmlns="http://ws.apache.org/ns/synapse" name="send_seq">
<header name="Action" scope="default" value="urn:getQuote"/>
<call>
<endpoint name="simple">
<address uri="http://localhost:9000/services/SimpleStockQuoteService"/>
</endpoint>
</call>
</sequence>
Build and run¶
Create the artifacts:
- Set up WSO2 Integration Studio.
- Create an ESB Solution project.
- Create the proxy service with the configurations given above.
- Deploy the artifacts in your Micro Integrator.
Set up the back-end service:
- Download the stockquote_service.jar.
-
Open a terminal, navigate to the location of the downloaded service, and run it using the following command:
java -jar stockquote_service.jar
Invoke the proxy service:
-
Send a request to get the IBM stock quote and see that a JSON response is received with the IBM stock quote.
HTTP method: POST Request URL: http://localhost:8290/services/ContentBasedRoutingProxy Content-Type: text/xml;charset=UTF-8 Message Body: <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ser="http://services.samples" xmlns:xsd="http://services.samples/xsd"> <soapenv:Header/> <soapenv:Body> <ser:getQuote xmlns:ser="http://services.samples" xmlns:xsd="http://services.samples/xsd"> <ser:request> <xsd:symbol>IBM</xsd:symbol> </ser:request> </ser:getQuote> </soapenv:Body> </soapenv:Envelope>
{ "Envelope": { "Body": { "getQuoteResponse": { "change": -2.86843917118114, "earnings": -8.540305401672558, "high": -176.67958828498735, "last": 177.66987465262923, "low": -176.30898912339075, "marketCap": 56495579.98178506, "name": "IBM Company", "open": 185.62740369461244, "peRatio": 24.341353665128693, "percentageChange": -1.4930577008849097, "prevClose": 192.11844053187397, "symbol": "IBM", "volume": 7791 } } } }
-
Send a request to get the MSFT stock quote and see that an XML response is received with the MSFT stock quote.
HTTP method: POST Request URL: http://localhost:8290/services/ContentBasedRoutingProxy Content-Type: text/xml;charset=UTF-8 Message Body: <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ser="http://services.samples" xmlns:xsd="http://services.samples/xsd"> <soapenv:Header/> <soapenv:Body> <ser:getQuote xmlns:ser="http://services.samples" xmlns:xsd="http://services.samples/xsd"> <ser:request> <xsd:symbol>MSFT</xsd:symbol> </ser:request> </ser:getQuote> </soapenv:Body> </soapenv:Envelope>
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"> <soapenv:Body> <soapenv:Envelope xmlns:ax21="http://services.samples/xsd" xmlns:ns="http://services.samples"> <soapenv:Body> <ns:getQuoteResponse> <ax21:change>-2.86843917118114</ax21:change> <ax21:earnings>-8.540305401672558</ax21:earnings> <ax21:high>-176.67958828498735</ax21:high> <ax21:last>177.66987465262923</ax21:last> <ax21:low>-176.30898912339075</ax21:low> <ax21:marketCap>5.649557998178506E7</ax21:marketCap> <ax21:name>MSFT Company</ax21:name> <ax21:open>185.62740369461244</ax21:open> <ax21:peRatio>24.341353665128693</ax21:peRatio> <ax21:percentageChange>-1.4930577008849097</ax21:percentageChange> <ax21:prevClose>192.11844053187397</ax21:prevClose> <ax21:symbol>MSFT</ax21:symbol> <ax21:volume>7791</ax21:volume> </ns:getQuoteResponse> </soapenv:Body> </soapenv:Envelope> </soapenv:Body> </soapenv:Envelope>