Sample 852: Introduction to Synapse Splitter-Agrregator eip function template
<definitions xmlns="http://ws.apache.org/ns/synapse">
<import xmlns="http://ws.apache.org/ns/synapse" name="EipLibrary" package="synapse.lang.eip" />
<sequence name="main">
<call-template target="synapse.lang.eip.splitter_aggregator">
<with-param name="attach_path_enabled" value="true"/>
<with-param name="endpoint_uri" value="http://localhost:9000/services/SimpleStockQuoteService"/>
<with-param xmlns:m0="http://services.samples" name="iterate_exp" value="{{//m0:getQuote/m0:request}}"/>
<with-param xmlns:m0="http://services.samples" name="attach_path" value="{{//m0:getQuote}}"/>
<with-param name="sequence_ref" value="enr"/>
<with-param xmlns:m0="http://services.samples" name="aggregator_exp" value="{{//m0:return}}"/>
<with-param name="oncomplete_seq_enabled" value="true"/>
</call-template>
</sequence>
<sequence xmlns="http://ws.apache.org/ns/synapse" name="enr">
<log level="custom">
<property name="text" value="seqhit"/>
</log>
<enrich>
<source xmlns:m0="http://services.samples" clone="true"
xpath="//m0:return[not(preceding-sibling::m0:return/m0:last <= m0:last) and not(following-sibling::m0:return/m0:last < m0:last)]"/>
<target type="body"/>
</enrich>
<send/>
</sequence>
</definitions>
Objective
This sample is an introduction to Synapse Splitter-Aggregator combined function template.
Executing the Client
In this sample, the message sent to Synapse will be splitted according to the given Xpath expression and does a synchronized call for the given endpoint and aggregates replies. Then mediates to the defined target sequence which filter the response which contains the best quote and send back to the client. Here it only uses Splitter-Aggregator template.
Invoke the client as follows.
ant stockquote -Dtrpurl=http://localhost:8280/ -Ditr=4
The above command will send a request containing four fragments in it.
Back to Catalog