Hello SharePointers,
I am working on my flow and I see that I am unable to Send approval request to a group in MS flow.
Some Background
It seems that flow will only send approval request emails to an individual user. This case won’t work in the long run, we always need to change the flow and remove and add approvers in Microsoft flow.
Is there a way to skip this process and send approvals to group? To Send approval request to a group in MS flow we followed below steps.
Yes, Of course!!! We have a solution for this.
Currently, Flow doesn’t have the ability to let you assign approval to a group directly. However, we have a workaround to send approvals to a SharePoint Group.
That’s enough about the background. Let us see How to Do it.
How to do it.
TO achieve this functionality we need to follow several steps. These detailed steps are given below.
Step 1: Be ready with your SharePoint site and List where you want to apply an approval process.
Step 2: Create a Microsoft Flow from blank. For this go to flow.microsoft.com from your tenant. Then click on Create from Blank.
Step 3: For the trigger, Select ‘SharePoint – When Item is Created‘ and provide your site URL and List/Library URL.
data:image/s3,"s3://crabby-images/669a8/669a8562e8e140d477c8234912d3a6af795855a4" alt="Approval Flow SharePoint Groups"
Step 4: Add ‘Send an HTTP request’ action to the flow. Configure all the API’s properly. _api/web/sitegroups/getbyname(‘SharePoint group name’)/users
data:image/s3,"s3://crabby-images/9175e/9175e9543b75eac32ffa58d563648741070df40a" alt="Microsoft Flow Assign approvals to SharePoint groups Microsoft Flow Assign approvals to SharePoint groups"
Step 5: At this point, we need a variable to store user emails, So Add an action- Initialize variable and configure it like below.
data:image/s3,"s3://crabby-images/7746e/7746edff7da8fe4fce23bfc6977c9b3f18689b7d" alt="Microsoft Flow approval SharePoint Group Microsoft Flow approval SharePoint Group"
Step 6: Now we need to parse a response from the SharePoint Rest API call. Hence we need to add an action from Data Operations- Parse JSON. As a content add Body from Send HTTP request from SharePoint, which is created earlier.
data:image/s3,"s3://crabby-images/a797a/a797aaa679070dd4f5a076604f266253fd6399e4" alt="approval flow SharePOint Group approval flow SharePOint Group"
We need to tell flow what schema the response is so that we can use the SharePoint Group response data properly within a flow. Without doing this Flow can’t read values from a bunch of text.
To do this, you can copy below JSON schema and Paste it in Schema section.
To save time , here is full schema you need to add in your flow to get approvers properties like name, email ,etc.
{
"type": "object",
"properties": {
"d": {
"type": "object",
"properties": {
"results": {
"type": "array",
"items": {
"type": "object",
"properties": {
"__metadata": {
"type": "object",
"properties": {
"id": {
"type": "string"
},
"uri": {
"type": "string"
},
"type": {
"type": "string"
}
}
},
"Alerts": {
"type": "object",
"properties": {
"__deferred": {
"type": "object",
"properties": {
"uri": {
"type": "string"
}
}
}
}
},
"Groups": {
"type": "object",
"properties": {
"__deferred": {
"type": "object",
"properties": {
"uri": {
"type": "string"
}
}
}
}
},
"Id": {
"type": "integer"
},
"IsHiddenInUI": {
"type": "boolean"
},
"LoginName": {
"type": "string"
},
"Title": {
"type": "string"
},
"PrincipalType": {
"type": "integer"
},
"Email": {
"type": "string"
},
"IsEmailAuthenticationGuestUser": {
"type": "boolean"
},
"IsShareByEmailGuestUser": {
"type": "boolean"
},
"IsSiteAdmin": {
"type": "boolean"
},
"UserId": {
"type": "object",
"properties": {
"__metadata": {
"type": "object",
"properties": {
"type": {
"type": "string"
}
}
},
"NameId": {
"type": "string"
},
"NameIdIssuer": {
"type": "string"
}
}
}
},
"required": [
"__metadata",
"Alerts",
"Groups",
"Id",
"IsHiddenInUI",
"LoginName",
"Title",
"PrincipalType",
"Email",
"IsEmailAuthenticationGuestUser",
"IsShareByEmailGuestUser",
"IsSiteAdmin",
"UserId"
]
}
}
}
}
}
}
The complete action looks like below
data:image/s3,"s3://crabby-images/47c4e/47c4e48f736dd680caa1e22d3e0b1b644e5dd875" alt="Microsoft flow for Office 365"
Step 7: Now we got the data of all users. At this point we are going to retrieve all user’s email addresses into using Apply to each action.
data:image/s3,"s3://crabby-images/cdcb9/cdcb9805919444b5fcd20c17d14f5037cd300945" alt="Apply to each in MS Flow"
Step 8: Add ‘results’ from Parse JSON action.
data:image/s3,"s3://crabby-images/97495/97495dbe08870f039a1a4bb070ad56e14ed5b0ae" alt="Microsoft Flow get Approver from list Microsoft Flow get Approver from list"
Step 9: Add new action within Apply to each called –Append to a string variable. Within this, we need to set our initialized Variable VarApproverEmail and set the value Email.
data:image/s3,"s3://crabby-images/86f32/86f328c0ae75af9c0c9162c9d18ea8d210034d37" alt="sharepoint rest api get group members sharepoint rest api get group members"
Very Important, DO NOT FORGET TO ADD SEMICOLON (;) AFTER EMAIL VALUE.
Step 10: Finally, we are all set to get approvers from SharePoint Group. Let us go ahead and use them into Approval Process. So We need to add an action – Start Approval Process. Fill the required Data and in the “Assigned To” field we need to click on see more and find our variable from ‘Dynamic Content’.
data:image/s3,"s3://crabby-images/169d2/169d2bf28ebde3579a2e94571916f32b86b3683a" alt="Send Approval Request to SharePoint group in MS Flow Send Approval Request to SharePoint group in MS Flow"
Then Choose ‘VarApproverEmail’ variable.
data:image/s3,"s3://crabby-images/77508/77508103689557c6e008955e7ddecb38379459f3" alt="MIcrosoft Flow Dynamic approval Microsoft Flow dynamic approval"
A complete flow Look like this.
data:image/s3,"s3://crabby-images/b8b2d/b8b2df86c39aabed7291474a698b550b62e15b0a" alt="microsoft flow approval multiple approvers Send microsoft flow send email to sharepoint group"
Give a name to flow, save it and Run the FLOW! Bingo! All Done.
data:image/s3,"s3://crabby-images/e9250/e92500abbee1a6acef72e6e3601173700c864fc2" alt="comment please Please comment."
Like!! Really appreciate you sharing this blog post.Really thank you! Keep writing.
A big thank you for your article.
A big thank you for your article.
Hi there, after reading this amazing paragraph i am as well delighted to share my knowledge here with friends.