In this post I will provide an example on how to process events generated by a flow using the default IBM Integration Bus monitoring event capability.
The example will show how
The principle is simple:
The example in this post shows how to create mail with attachments using ESQL but this could be easily made using Java as well.
The event generated as a well defined structure and the schema can be imported into a library using new model -> IBM predefined model.
Any nodes in a flow can be configured to generate events (Generating events in WebSphere Message Broker) that may contain context information and payload.
It is for example possible to configure a node to include the localEnvironment, ExceptionList and Message tree structure (under Root). These information will be placed into the IIB events under the folder "complexContent".
Note that the LocalEnvironment is reset when an exception occurs, so the data that would have been stored in this tree would be wiped when the message is propagated to the catch terminal of the input node (will be covered in a future post).
Finally it is also possible to include the full payload (as it was received) by selecting in the monitoring node properties "include payload as bitstream". The payload will then be included into the IIB events under "BistreamData".
The example will show how
- to serialize a tree into BLOB using ESQL
- how to send a mail with attachment
- How to create/prepare the LocalEnvironment and Root for the EmailOutput node
- The usage of the business event capabilities provided by IIB
The principle is simple:
- Configure a flow to generate an IIB event
- Create a subscription to this event with a WMQ Queue as endpoint
- Create a flow that consumes these events and send an email with attachments
The example in this post shows how to create mail with attachments using ESQL but this could be easily made using Java as well.
Configure a flow to generate an IIB event
The event generated as a well defined structure and the schema can be imported into a library using new model -> IBM predefined model.
Any nodes in a flow can be configured to generate events (Generating events in WebSphere Message Broker) that may contain context information and payload.
It is for example possible to configure a node to include the localEnvironment, ExceptionList and Message tree structure (under Root). These information will be placed into the IIB events under the folder "complexContent".
Note that the LocalEnvironment is reset when an exception occurs, so the data that would have been stored in this tree would be wiped when the message is propagated to the catch terminal of the input node (will be covered in a future post).
Finally it is also possible to include the full payload (as it was received) by selecting in the monitoring node properties "include payload as bitstream". The payload will then be included into the IIB events under "BistreamData".
Create a subscription
The IIB runtime is publishing the IIB events on the WMQ topic "$SYS/Broker/IBMIBus/Monitoring/#".
Using the WMQ Explorer you create a subscription to these events and select a destination queue:
The flow that sends email
The flow is very simple: MQInput -> ComputeNode -> EmailOutput node
The compute node is used to create and configure the message that will be send using the emailoutput node.
The node it self is configured the minimum properties: server:port, email to, from and security.
The rest will be provided by the code in ESQL (subject, body content and attachments).
In this example the complexContent included in the incoming business event is serialized into bitstream and will be send by mail as attachment.
The payload if present is also send as attachment.
The body of the mail is made of event origin data and using a DFDL to have a text document separated with CRLF.
The code is provided here after:
No comments:
Post a Comment