This is the first of two Power Automate Flows that are used by Mercy Corps' Data Protection and Privacy team (DPP) to handle data subject requests. This flow completes three actions when a data subject fills out our Data Subject Request form:
- creates a new item in a SharePoint list using input data from a form (also updates the status of that item to
New
). - sends confirmation email to the data subject that form has been received and that DPP will follow-up.
- Sends notification email and Teams chat message internally to flag the need to check the SharePoint list and update status of new item to
Approved
(which will trigger the second flow).
On it's own, this flow can be used to populate a list from form responses and send notifications. Together with the second flow in this repo, we can efficiently create data subject requests; send notifications to various system holders across our organization; and track the compliance of each system owner with the request. If we are audited, our flow provides detailed data concerning all actions taken to comply with the request. An overview of the assets used is below.
This flow uses the following concepts:
- Getting response details from a Microsoft Form.
- Creating a Sharepoint List item.
- Sending automated emails and Teams chats.
This flow requires a Microsoft Form and a List in SharePoint. You will need to map form fields to list columns. This example uses the following:
- Form fields -
Name
,physical address
,email
,country of citizenship
,request
(input as multiple options using radio buttons) - List fields (column headers) -
Name
,physical address
,contact
(input as email),Citizenship
(input as country),request type
(input fromrequest
selection in form),status
(items created with this flow are markedNew
), and various columns for systems that need to be checked for the request. This flow assumes two columns (labeledSystem 1
andSystem 2
), but you can add as many as you need.
Although built into this flow, it's helpful to remember that in order to pull information out of a form to be used in other actions you have to build a trigger for it: (see MS help here).
- Download the
.zip
file from theFlow-file
folder by clicking on "View raw" or the "Download" button. - Browse to your Power Automate and select the environment where you wish to import the sample
- From the toolbar, select Import, then Import package.
- In the Import package page, select Upload and choose the
.zip
file containing the sample flow. - You will need to change the relevant resources to connect with your account during the import. To do this, look for the
Select during import
link under the "Import Setup" column. Click this link, then look for your resources and connections to appear in the pop-up window. Select the appropriate resources then click save. See screenshot below.
- Once you've updated the required resources select Import
- Once the sample Flow is installed, you'll still need to update all the parameters, fields, etc. to point to the Forms and Lists in your Sharepoint site and update the assignees to individuals in your organization. These are detailed below.
- You may need to turn the flow on.
For further help importing Flows, see this blog post from Microsoft.
Following the installation steps above will load this flow into your environment. However, you'll need to edit several sections to make it work. Listed below are the changes that need to be made for each action starting from the top of the flow.
Form ID
- this drop down list should populate with your forms. If you haven't created a form yet, it won't show up!
As an aside, I found figuring out exactly where in my organization's Sharepoint to create the form a bit tricky. My original form didn't show up because it was a "group form", which I had to re-create in "my forms" - a barely perceptible link on the "group forms" page led me to this. I couldn't find a lot of documentation about the difference between these two types of forms, but this thread in a community forum explains it.
Form ID
- Same as above: select your form.Response Id
- Use the dynamic content picker to replace this and ensure that the Id is coming from your form.
This is where new list items are created using the responses to the form.
Site Address
- Change to the SharePoint site that contains your list.List Name
- Change to your list. The dropdown should automatically populate ifSite Address
is correctly configured.- The remaining fields (e.g.
Name
,Data Subject Physical address
, etc.) all come from the columns in your list. Use the dynamic content picker to select the values you need from Get response details: you are mapping the form fields to the column you want them to appear in. The values for theStatus Value
are pulled from the List itself. In this case, I want any new item to have a value ofNew
.
This is the generic template email that is sent to the data subject.
To
- Use the dynamic content picker to set the value for this to whatever field in your form contains the email address of the data subject.Subject
- Keep or change to whatever you want to the subject line of the email to be.Body
- You can configure the email however you need it. In this flow, I'm using the first and last name fields from the form to automatically create the opening line, then the rest is just static text.
This is the email that will go to the owner of the data subject request process.
To
- Change to whoever is the DSR owner in your organization.Subject
- Keep or change to whatever you want to the subject line of the email to be.Body
- You can configure the email however you need it. In this flow, I'm using the first and last name fields from the form to display who the request is from. I've also included a link to the list.
Because I keep Teams open all day (and sometimes ignore email) I wanted to get a Teams notificaiton as well.
Post as
- You can configure this to post to a channel as you, but I prefer to be clear that it's a bot doing the sending.Post in
- Again, you can set whatever channel you like, such as a group chat of folks handling DSR requests, but I keep it in single channel between me and the bot.recipient
- Whoever the DSR owner is in your organization.Message
- same as theBody
field in the email: configure this to display whatever information you want to see.
This repository is maintained by the Data Protection & Privacy team at Mercy Corps. If you are a Mercy Corps staff member and need help duplicating this flow for another use case, reach out to dataprotection@mercycorp.org for assistance. Anyone can create a new issue for any problems and submit updates or additions to this material via a Github pull request. We appreciate any feedback!
This code is provided as is without any warranty of any kind, either express or implied, including any implied warranties of fitness for a particular purpose, merchantability, or non-infringement.