Receiving Custom XML Events via HTTP¶
Purpose¶
This application demonstrates how to configure WSO2 Streaming Integrator to receive events to the SweetProductionStream
via HTTP transport in XML custom format and log the events in LowProductionAlertStream
to the output console.
Prerequisites:¶
Save this sample.
Executing the Sample:¶
- Start the Siddhi application by clicking on 'Run'.
- If the Siddhi application starts successfully, the following messages would be shown on the console.
Testing the Sample:¶
Option 1: Publish events with HTTP sample client:¶
Navigate to {WSO2SIHome}/samples/sample-clients/http-client
and run ant
command as follows:
Run ant
command in the terminal as follows:
Option 2: Publish events with curl command:¶
curl -X POST -d '<events><item><id>sugar</id><amount>300</amount></item></events>' http://localhost:8006/productionStream --header "Content-Type:application/xml"
Option 3: Publish events with Postman:¶
- Install 'Postman' application from Chrome web store.
- Launch the application.
- Make a 'Post' request to 'http://localhost:8006/productionStream' endpoint. Set the Content-Type to 'application/xml' and set the request body in xml format as follows.
Notes:¶
If you edit this application while it's running, stop the application -> Save -> Start. If the message "Source Listener has created for url http://localhost:8006/productionStream" does not appear,it could be due to port 8006, defined in the Siddhi application is already being used by a different program. To resolve this issue, please do the following, * Stop this Siddhi application (Click 'Run' on menu bar -> 'Stop') * Change the port 8006 to an unused port, in this Siddhi application's source configuration. * Start the application and check whether the specified messages appear on the console
Viewing the Results:¶
See the output. Following message would be shown on the console.
ReceiveHTTPinXMLFormatWithCustomMapping : LowProducitonAlertStream : Event{timestamp=1511939868628, data=[sugar, 300.0], isExpired=false}
@App:name("ReceiveHTTPinXMLFormatWithCustomMapping")
@App:description('Receive events via HTTP transport in XML format with custom mapping and view the output on the console.')
@Source(type = 'http', receiver.url='http://localhost:8006/productionStream', basic.auth.enabled='false',
@map(type='xml',@attributes( name = "item/id", amount = "item/amount")))
define stream SweetProductionStream (name string, amount double);
@sink(type='log')
define stream LowProductionAlertStream (name string, amount double);
-- passthrough data in the SweetProductionStream into LowProducitonAlertStream
@info(name='query1')
from SweetProductionStream
select *
insert into LowProductionAlertStream;