This post will show you how to make a REST call to the SharePoint API and process the JSON response using Microsoft Flow.
Background
As part of a solution I was building I needed to count the number of users in a SharePoint permission group. Unfortunately, the number of users is not returned in the SharePoint Users, groups, and roles REST API UserCollection resource. A GET request to the UserCollection returns:
data:image/s3,"s3://crabby-images/e5212/e521225258a1f0d705abd418da4d4fd7a110598c" alt="OData Representation"
OData Representation
On inspection of the response I could see that if I could parse the JSON to extract the ‘Email’ addresses into an array I could then count them.
Steps
data:image/s3,"s3://crabby-images/dbb67/dbb678af7ba9c826319f32b842df3477181d2bca" alt="Steps"
Steps
#1 – Get the data from SharePoint using a HTTP request action
The first action is to issue a GET request to the _api/web/sitegroups(<group id>)/usersendpoint:
data:image/s3,"s3://crabby-images/22ace/22ace70210b5958ec5d34f53bd8f0398a0313f39" alt="Send a HTTP request"
Send a HTTP request
The <groupid> of 350 corresponds to my target group in SharePoint.
data:image/s3,"s3://crabby-images/8c64a/8c64add098b87da24c9ce8cc268e692f75882806" alt="ContractUsers"
ContractUsers
Hopefully you’ve noticed that in the Uri field I’ve added a $select value to my request.
_api/web/sitegroups(350)/users?$select=Email
The $select value has two effects:
- It reduces the size of the object returned to only those defined as required items i.e. not the full list shown above. Through my experimentation I have learned that the __metadata array is defined as required in the API and so it is provided with every call. The remainder is defined as optional by default.
- It includes the Email of each user. (Where the user is a group this value will be blank)
#2 – Parse the return as JSON
data:image/s3,"s3://crabby-images/6ad94/6ad943213d1ef45380d1ed6ee302db2012aadda6" alt="Parse JSON"
Parse JSON
The Parse JSON action is not well documented… It is a member of the Data Operations actions. The action includes a nice feature that allows you to construct a schema based off an example response.
data:image/s3,"s3://crabby-images/2bca6/2bca61bfdebc3a759f79cd100092f3f0f18c2d57" alt="Parse JSON"
Parse JSON
In my case the response from #1 looked like this:
data:image/s3,"s3://crabby-images/7a60c/7a60c1bf72362c7714dd53e3105e0c6e6bef04ba" alt="metadata"
metadata
You can get the response by running your Flow and then copying the response out from the Output.
data:image/s3,"s3://crabby-images/648c9/648c9d1316a87bbda142c94200f68098c5532dfa" alt="Send an HTTP request to SharePoint"
Send an HTTP request to SharePoint
data:image/s3,"s3://crabby-images/efb62/efb6204ce4a3424416af2e2753c07d0abe1c86ad" alt="Schema"
Schema
Note if you then reopen the sample schema generator it will wipe out the schema currently held by the action so it is worth saving the schema somewhere safe!
#3 – Initialize a variable to hold the parsed JSON for use in an Apply to Each action
data:image/s3,"s3://crabby-images/bdcde/bdcdedbb2f918c5800a8f6acedbb99a88b5a0c8d" alt="Initialize a variable"
Initialize a variable
We need somewhere to store the emails or empty responses!
#4 – Use an Apply to Each action to append responses into the array
data:image/s3,"s3://crabby-images/68499/684992f4224a5360df8d6a6a54f353cf4a98cf42" alt="Apply to each"
Apply to each
The act of parsing the JSON makes each node available as dynamic content:
data:image/s3,"s3://crabby-images/adb76/adb763a307811e3af7e54a156b1d46f85c5564d8" alt="Dynamic content"
Dynamic content
The results of #3 are stepped through with the value of the current ‘Email’ node added to the array using a Append to array variable action (from the Data Operations actions).
data:image/s3,"s3://crabby-images/68499/684992f4224a5360df8d6a6a54f353cf4a98cf42" alt="Apply to each"
Apply to each
#5 – Get the number of users by counting the length of the array
data:image/s3,"s3://crabby-images/87fcf/87fcfa63bf650740a03195e494e006518109f6c8" alt="Number of users"
Number of users
Finally the length of the array is calculated using a Length expression to yield the number of users (which in this case is 2).
length(variables('userEmails'))
data:image/s3,"s3://crabby-images/36edb/36edb65de894d790b6b2195a7de7aed269cbb45a" alt="The length of the array"
The length of the array
Reference:
Denton, S (2018). Counting SharePoint users using Microsoft Flow. Available at: https://buildbod.com/2018/06/20/counting-sharepoint-users-using-microsoft-flow/ [Accessed: 2 August 2018].