How to get Paging Cookie while retrieving data using Fetch XML Query in Microsoft Flow
Introduction
Microsoft Flow is bringing new connectors day by day to ease the life of its users.
With the new connector for Common Data Service, while performing the List Records action, now we have the provision to use Select Query, Fetch XML Query and Skip token, rest of the other things remaining the same.
data:image/s3,"s3://crabby-images/d9fc0/d9fc0f3f70b2b888f7bbdfa821efd1198b6ab465" alt="Microsoft Flow"
Today, we’ll see how we can use Fetch Xml Query and then get the paging cooking to re-use it for next retrieve request.
Consider a scenario where I have an on demand flow which is called by passing the paging cookie, page number and count as parameters.
Based on the parameters passed, the retrieval takes place and also the necessary actions are performed on the retrieved records. After the retrieval, if there are more records, then the flow returns back the paging cookie for next retrieval.
Let’s take a look at how to design a Microsoft Flow for this request.
Step 1:
Select an HTTP Request Trigger.
data:image/s3,"s3://crabby-images/6c976/6c9761d126af5a974e05ca4b37b4a454d6e0965d" alt="Microsoft Flow"
Given below is the JSON Schema as per the requirement.
{ "type": "object", "properties": { "paging-cookie": { "type": "string" }, "page": { "type": "string" }, "count": { "type": "string" } } }
Step 2:
Initialize the paging cookie. This is the paging cookie sent as a parameter in the http request.
data:image/s3,"s3://crabby-images/02eee/02eeea8925834830c854fd1b360c08deaf9a7115" alt="Microsoft Flow"
Value expression,
if(empty(triggerBody()?[‘paging-cookie’]),”,concat(‘paging-cookie=”’,triggerBody()?[‘paging-cookie’],””))
Note: The above Value expression makes sure that we handle the empty paging cookie scenario as well.
Step 3:
Retrieve the records using Fetch XML.
data:image/s3,"s3://crabby-images/5fdf0/5fdf01c3626e485e2b4c669a97e336086369d77f" alt="Microsoft Flow"
Here,
count – It is sent over as a parameter in the http request.
page – It is sent over as a parameter in the http request.
pagingCookie – This is the variable initialized in Step 2.
Step 4:
Perform necessary actions on the records retrieved in Step 3.
data:image/s3,"s3://crabby-images/23237/2323745761e07f1f2fa3dfa3b5da90c2a2aef861" alt="Microsoft Flow"
Step 5:
Parse the JSON of the response from Step 3. This helps us get the paging cookie.
data:image/s3,"s3://crabby-images/1200e/1200e80a7e5aa43f0409013c63397931aaef1491" alt="Microsoft Flow"
For copying purpose, I am pasting here the JSON.
{ "type": "object", "properties": { "@@Microsoft.Dynamics.CRM.fetchxmlpagingcookie": { "type": "string" } } }
Step 6:
Return back the paging cookie to where the request was originated.
data:image/s3,"s3://crabby-images/ec78e/ec78ed4fbce5fa3e2fd2383f7228d7fdc82a377d" alt="Microsoft Flow"
The dynamic parameter used in the above bod is a by-product of Step 5.
Note:
Out of the box Pagination brings the data in the multiple of 512, so if you have specific pagination needs, then using paging cookie makes more sense.
data:image/s3,"s3://crabby-images/f3f6d/f3f6d08a55228d2fd5ace016ff73a9a5b5c8ac51" alt="Microsoft Flow"
Flow in its entirety:
data:image/s3,"s3://crabby-images/08318/08318d6b098332da8556b1e163166680bbf1aff1" alt="Microsoft Flow"