Register now to learn Fabric in free live sessions led by the best Microsoft experts. From Apr 16 to May 9, in English and Spanish.
Hi all!
I have succesfully implemented row level security using the guide:
https://www.youtube.com/watch?v=Sge_g9hTXWE&feature=emb_logo&ab_channel=PragmaticWorks
Now the only issue is that I can have multiple users (userID's) with the same email adress and my DAX Filter on the table I have implemented RLS on expects a singel UserID. How can I change this DAX Formula in a way that multiple USerID's can be the input of the filter.
DAX Formule on my CustomerStructure table:
[ID] IN SELECTCOLUMNS(
FILTER(
Security_User_CustomerStructure,
Security_User_CustomerStructure[PersonID] = LOOKUPVALUE(Security_Users[PersonID], Security_Users[Email], USERNAME() )
),
"ID", [CustomerStructureID]
)
Printscreens:
Solved! Go to Solution.
Hi @planbitionbi ,
Please refer to the following measure:
[ID]
IN SELECTCOLUMNS (
FILTER (
Security_User_CustomerStructure,
Security_User_CustomerStructure[PersonID]
IN CALCULATETABLE (
VALUES ( Security_Users[PersonID] ),
FILTER ( Security_Users, Security_Users[Email] = USERPRINCIPALNAME () )
)
),
"ID", [CustomerStructureID]
)
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Best Regards,
Dedmon Dai
Hi!
Thanks a lot for your feedback. Unfortunately it's throwing an error like below. Can you see why it's wrong? Something with the IN clause:
Hi @planbitionbi ,
Please refer to the following measure:
[ID]
IN SELECTCOLUMNS (
FILTER (
Security_User_CustomerStructure,
Security_User_CustomerStructure[PersonID]
IN CALCULATETABLE (
VALUES ( Security_Users[PersonID] ),
FILTER ( Security_Users, Security_Users[Email] = USERPRINCIPALNAME () )
)
),
"ID", [CustomerStructureID]
)
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Best Regards,
Dedmon Dai
Hi @planbitionbi ,
I suggest you use USERPRINCIPALNAME ( ) instead of USERNAME() and you can change the dax to :
[ID] IN SELECTCOLUMNS(
FILTER(
Security_User_CustomerStructure,
Security_User_CustomerStructure[PersonID] IN CALCULATETABLE(VALUES(Security_Users[PersonID]),FILTER(Security_Users,Security_Users[Email] = USERPRINCIPALNAME())),
"ID", [CustomerStructureID]
)
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Best Regards,
Dedmon Dai
Covering the world! 9:00-10:30 AM Sydney, 4:00-5:30 PM CET (Paris/Berlin), 7:00-8:30 PM Mexico City
Check out the April 2024 Power BI update to learn about new features.
User | Count |
---|---|
110 | |
95 | |
76 | |
65 | |
51 |
User | Count |
---|---|
146 | |
109 | |
106 | |
88 | |
61 |