I have a sample application that consists of two tables, Forms and Form Types and a Model-Driven Application called Forms Model App.
data:image/s3,"s3://crabby-images/cd3df/cd3dfc0850f25fb295964727f7e36a4c2316772b" alt=""
Currently I have three Form Types:
Form Type A
Form Type B
Form Type C
When creating a Form you have to assign a Form Type.
I had a new requirement come up.
I wanted to allow certain people to have access to edit certain Forms based on the Form Type.
After giving this some thought 💭, I think I came up with a good solution that I will share with you.
Create Security Role for Forms User
I navigated to the Power Platform Admin Center and created a Security Role called Forms User
in the environment where my solution lives.
data:image/s3,"s3://crabby-images/730b2/730b2674f502fcee578d041c3cb89877e453fabd" alt=""
I made sure to set Include App Opener for running Model-Driven apps to On
.
I gave the Security Role the appropriate permissions to access the Forms and Form Types tables.
data:image/s3,"s3://crabby-images/5e08a/5e08a6c2df18b578d861dc6b7225608d76098b55" alt=""
🫵Notice I gave the Forms table mostly User
permissions, meaning the user would only be able to do the action on records they owned.
I then added the Security Role to the solution.
Create Teams
I then navigated back to my environment in Power Platform Admin Center and under Settings clicked Teams.
I added three teams, one for each form: Form Type A Team
, Form Type B Team
and Form Type C Team
.
I added the Security Role for Forms User
to each.
data:image/s3,"s3://crabby-images/6a9bd/6a9bd0dbedc41bb225bfb11fed78e3ccb529a14d" alt=""
I then added Demo User to Form Type A Team
and Form Type C Team
.
data:image/s3,"s3://crabby-images/6c2d2/6c2d23a1f7030b22e5f60c1a483a493e1027f187" alt=""
Create Flow to Update Owner
In order for this to work correctly, I need to change the Owner of the Form to the correct Team based on the Form Type
.
The flow sets the Owner
of the Form to the Owner
of the Form Type.
data:image/s3,"s3://crabby-images/66773/667734ee4c812ea5f0a1b2c199c81c42aec55c06" alt=""
I set the Owner of each of the Form Types to the respective team:
For the Form Type named Form Type A
, I set the Owner to Form Type A Team
. I repeated for Form Type B
and Form Type C
, respectively.
What happens when the flow runs⚙️?
It looks at the Owner
of the Form Type assigned to the Form, and makes that the Owner
of the Form, in this case, it will always be a Team.
Test the Application and Security
Now I’m ready to test🧪 my application.
From the app maker side of things, where I have the appropriate permissions, I created several Forms of different Form Types.
data:image/s3,"s3://crabby-images/b6e26/b6e2611a6433d9ba32dd1396da0519203fb81f83" alt=""
I now log 🔒 in as my Demo User.
As expected, I only see Forms that are of Form Type A
and Form Type C
.
data:image/s3,"s3://crabby-images/3cb2d/3cb2d3135f84899561951b896a16db64a64e82e0" alt=""
I think it took me longer to think about how to do this, than actually do it!
If there is a better way, please share! 🙂
Check out the solution for yourself at FormsSolution_1_0_0_1.zip.
Don’t forget to setup the Teams in the Power Platform Admin Center for your environment.
Discover more from Matt Ruma
Subscribe to get the latest posts sent to your email.