data:image/s3,"s3://crabby-images/ce6cf/ce6cff5035824a7aacd9b6a76494f9d55bc866d1" alt="Aggregator in SAP CPI : Tutorial CPI Tutorials"
Aggregator in SAP CPI : Tutorial
Overview
The aggregator is used to combine the incoming chunks of messages into one single message. The Aggregator will do multi-mapping while combining the messages.
Table Of Content
There are two kinds of Aggregation Algorithm available.
- Combine : This will combine the incoming messages without any gurantee on the order of the messages.
- Combine In Sequence : This will combine the incoming messages in exact order.
Example
The incoming message is in the below format,
<Order_MT>
<orderNumber>1</orderNumber>
<prodID>1</prodID>
<supplierName>Walt</supplierName>
<productName>Timber</productName>
<lastProd>No</lastProd>
</Order_MT>
The requirement is to Aggregate the incoming messages having different prodID with orderNumber=1 as a single message until lastProd=Yes.
The sample integration flow will look as below
data:image/s3,"s3://crabby-images/db0e9/db0e9aee2b4377c9e84e122e2d4db92f50003596" alt="Integration Flow"
Execution Steps
Step 1: Configure the HTTPS sender adapter to create an endpoint to access the Integration Flow.
data:image/s3,"s3://crabby-images/a6e91/a6e913e662513a6c02108eaf53d721e06bdefb0f" alt="HTTPS Sender Adapter"
Step 2: Select Aggregator from Routing pallet and configure as below.
data:image/s3,"s3://crabby-images/2d5d6/2d5d680dd0f83cc6c3472e1fc04df461717022c4" alt="Aggregator"
Field | Tab Name | Value | Explanation |
Correlation Expression (Xpath) | Correlation | /Order_MT/orderNumber | Expression to the node relative to which the Aggregation should happen. Here we need to aggregate the message with the similar order number. |
Incoming Format | Aggregation Strategy | XML(Same Format) | The format of the Incoming Message. To date, the only XML is allowed |
Aggregation Algorithm | Aggregation Strategy | Combine in Sequence | Combine in sequence : Aggregated message will retain the original Sequence |
Message Sequence Expression(Xpath) | Aggregation Strategy | /Order_MT/prodID | Expression to the node based on which the sequence is determined. Here we need a sequence based on prodID. |
Last Message Condition (Xpath) | Aggregation Strategy | /Order_MT/lastProd=’Yes’ | Expression with a value represents the end of the message. Here if the value in lastProd is Yes, then it indicates that it is the last message with that orderNumber.The Aggregation stops here. |
Completion Timeout (min) | Aggregation Strategy | 60 | The time interval between two messages (idle time) before the Aggregation stops automatically. |
Datastore Name | Aggregation Strategy | AggregatorExample | The name of the data Store where the individual messages are stored for aggregation. |
data:image/s3,"s3://crabby-images/ac2db/ac2db5812d72a0c1b093a36f9531ca9de66c547a" alt="Aggregator Correlation"
data:image/s3,"s3://crabby-images/006ea/006ea5c6c59a91595c5f22ba6721ae7899be29f7" alt="Aggregator Strategy"
Step 3: Use a Content Modifier step to add an incoming message as the body.
data:image/s3,"s3://crabby-images/f54f5/f54f5922725efe46543367b2196dc1e339966deb" alt="Content Modifier"
Step 4 : Save and Deploy the flow.
Step 5 : Copy the EndPoint from Overview –> Manage Integration Content –> All. Change the Log Level to Trace under Log Configuration as shown below. This will allow you to see the payload at runtime.
data:image/s3,"s3://crabby-images/ba414/ba414d79389f320ea3e72d2a3526d595e43686f6" alt="End Point, Trace"
Testing the Flow using Postman
Step 6: Open the Postman app.
Keep the request in GET mode.
Paste the Endpoint copied in Step 5 into the URL tab.
In the Authorization tab, Choose TYPE: Basic Auth
Username: Client ID
Password: Client Secret
Client Id and Client Secret you will get when you create Process Integration Runtime Instance during tenant setup. ( Refer Step 34 of this post )
Paste the code given at the beginning of the article in the Body tab and Click on Send.
data:image/s3,"s3://crabby-images/98340/9834086ac440a174c0d4cb454c00fc7459ec2c69" alt="Postman"
Step 7: In the Overview window, you will see the message is processed. At the same time, a Data Store is created as below.
data:image/s3,"s3://crabby-images/f03c0/f03c034b0eac66e36406bd703b92c578574bc062" alt="Data Stores"
data:image/s3,"s3://crabby-images/7bdab/7bdab93e8bb461ce2dd795ea58f39d44528c4606" alt=""
Step 8: Change data in Postman as below and click on send. Remember to keep the orderNumber same and lastProd= No.
data:image/s3,"s3://crabby-images/245a0/245a012e4bcb9f20a3c1c6e712131c7fc3d72869" alt=""
Step 9: Check the Message processed and Data Store entry.
data:image/s3,"s3://crabby-images/c3e2d/c3e2d96c9285c0f7466fea0ad3e76bd059a0a700" alt=""
Step 10: Change the data again as Below and click on Send. This time make sure the orderNumber is the same and lastProd=Yes. This indicates that this will be the last message for aggregation.
data:image/s3,"s3://crabby-images/8e4c2/8e4c202dec496c49b380028973a5c48823dd01b3" alt=""
Step 11: Now the Message will be processed Successfully and the aggregated message will be available. The Data Store entry will be deleted as the Aggregation is complete.
data:image/s3,"s3://crabby-images/4c14e/4c14e9315db84eb1333bb898c35a061ec47f05c1" alt=""
Note that 3 individual messages that we triggered along with the final Aggregated messages are processed Successfully. Click on Final Aggregated Message. Under Logs, Click on Trace whose Status is completed.
data:image/s3,"s3://crabby-images/3c808/3c808cbb24dcd61b2163134b5a2280a43a30d8e4" alt="Monitoring"
Step 12 : In the window that opens, Click on END. Under the Message Content tab, Click on Payload. You will see all three messages triggered are aggregated into a single message.
data:image/s3,"s3://crabby-images/82759/82759fe5fc1555ddd986e02e40d6c7c4adfbae6c" alt="Payload"
FINAL VERDICT :
In conclusion, I hope you enjoyed reading this article on “Aggregator in SAP CPI: All You Need to Know”, If yes, then don’t forget to spread the word about it. Do send the feedback and to know more about it. Signing off sudarshanpatwardhan@gmail.com