Using Power Automate to change security role
data:image/s3,"s3://crabby-images/50969/50969ae68dd38ae27534fd63850a1147abd7056c" alt=""
The Scenario
We will be adding a Security Role / Field Security Profile to users in CDS. For this demo, our scenario will be grabbing all the users from a Office365 group and assigning them a certain Security Role / Field Security Profile.
The source of the users can be from anywhere:
– MS Form
– SharePoint
– Array inside the Flow
– Excel Table
– AAD Group / Office365 Group
Prerequisites
We will be using the Common Data Service Current Environment connector. This means that our Flow, MUST be created inside a Solution.
You will need appropriate permissions to be able to assign Security Roles and Profiles to
Steps
INFORMATION:
This Flow will work the exact same to add Field Security Profiles instead of Security Roles. The only changes you have to make are in the List records – Get Security Role, and the Relate records – Security Role to User. The changes are listed in the captions of those images.
We use a Variable to store the name of the Security Role we want to add to the users.
Than use a List records action on the Entity Security Roles
In our Filter Query we will use:
name eq ‘ ‘
Since we are using a variable to store the name of the Security Role, we pass this into the Filter Query
data:image/s3,"s3://crabby-images/a8412/a84125004978cf61a288de6d6ce335e757903afa" alt=""
Next, add a Compose action, to get the Odata URL. This URL is how we will add the Security Role to the User later on.
data:image/s3,"s3://crabby-images/73d9c/73d9ca37534c6f360b3e2a7fda15f3fc1f267583" alt=""
first(outputs('List_records_-_Get_Security_Role')?['body/value'])?['@odata.id'] |
To build the above expression follow these steps:
1) Inside the Compose action select Expression tab
2) Use the expression first()
3) Click back to Dynamic content tab
data:image/s3,"s3://crabby-images/66116/6611631d65c634819e96098735eff68c3545c5f0" alt=""
4) In the ( ) select the Dynamic content value from the List records action
data:image/s3,"s3://crabby-images/45840/45840a85b0369c92743b46574b6d062ce7b36082" alt=""
5) At the end of the expression add:
?['@odata.id'] |
6) Click OK
data:image/s3,"s3://crabby-images/1fb33/1fb33d16c16291c5a560018b673414a24653a93d" alt=""
7) Confirm the expression saved correctly by hovering your mouse over the expression
data:image/s3,"s3://crabby-images/e306f/e306f386ea3f8623f8e89842c99f0d26f8544ff4" alt=""
Next, use any data source / connector that meets your needs to get the emails of your users that you want to add – In this example I am using Office365 List group members
Add an Apply to each loop – So we can loop through each email and assign the Security Role
data:image/s3,"s3://crabby-images/d0cc5/d0cc561f98a94401d9420a784cb181bc063c91c7" alt=""
Inside the Apply to each loop, add a List records action on the Users entity
Filter Query = internalemailaddress eq ‘ ‘
Add your dynamic content that has the email address for the user to add inside the ‘ ‘
data:image/s3,"s3://crabby-images/0ae8c/0ae8ce3c6b2277fe239c2e89bbec1d6081465885" alt=""
Next, add a Compose action – to store the User ID (Unique ID)
We use the same technique as mentioned above, using first() and the field name
Add this to the end of your expression
1
|
?['systemuserid'] |
data:image/s3,"s3://crabby-images/5595c/5595c21a8314d6658da63e49a6906e9a8f541b94" alt=""
Still inside the Loop:
Add a Relate Records action.. This is one of the actions inside the Common Data Service Current Environment Connector.
Entity Name: Users
Item ID: The Compose – Get User ID Outputs
Relationship: Select ‘Security Role – systemuserroles_association’ from the drop-down
URL: The Compose – Security Role odata URL
data:image/s3,"s3://crabby-images/a884c/a884c69634e94315450a3c7bbf16008f1398f9a0" alt=""
Your action should look like this:
data:image/s3,"s3://crabby-images/7a4a6/7a4a6ceacdfe508a64b19437ef68f9568b4000c6" alt=""