Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

The Power BI DataViz World Championships are on! With four chances to enter, you could win a spot in the LIVE Grand Finale in Las Vegas. Show off your skills.

Reply
coriben
Helper I
Helper I

Permissions in the Role Manager with DAX

Hello, I’m trying to configure the permissions on my report to use Row Level Security in the Embedded version later.

 

I have the following table structure (This will be improved later, right now I’m trying to make it work in Power BI Desktop using the Roles Manager):

 

Users Table:

User_ID               Username

1                             User 1

2                             User 2

 

Permissions Table (These are our Client’s companies branches. Some of their employees can only see data for their own branch):

Permission_ID  Branch_Name

1                             Branch 1

2                             Branch 2

 

Bridge table between them (As you see, User 1 can see data for both branches):

ID           User_ID               Permission_ID

1             1                             1

2             1                             2

3             2                             2

 

And my data table. Every row of my data table has a “Branch” column. What I need is:

  1. Get what Branches each user can access ( username will be supplied by USERNAME() function);
  2. Filter the data table with said Branches;

 

I’ve managed to do it easily using actual filters (throwing the data at tables in the canvas and clicking), but I’m struggling to get it to work inside the Roles Manager.

 

Is this only possible with DAX? Is there an easier way?

 

Thanks!

1 ACCEPTED SOLUTION

Hello, thanks for your input. It's an App owns Data scenario, but I got it to work.

First, I included 2 fields in the bridge table so I don't need the Users and permissions tables anymore:
Username and Branch_name.

Then, the following DAX that I found did it:

[Data_table_branch_column]
    IN CALCULATETABLE (
        VALUES ( 'bridge_table'[Branch_name] ),
        FILTER (
            ALL ( 'bridge_table' ),
            [Username] = USERNAME ()
                || [Username] = USERPRINCIPALNAME ()
        )
    )

View solution in original post

3 REPLIES 3
v-jiascu-msft
Microsoft Employee
Microsoft Employee

Hi @coriben,

 

1. Establish proper relationships.

2. Create roles like below.

[User_ID] = 1

3. Assign the role to users.

 

What's your scenario? App owns data or User owns data?

 

 

Best Regards,

Dale

Community Support Team _ Dale
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

Hello, thanks for your input. It's an App owns Data scenario, but I got it to work.

First, I included 2 fields in the bridge table so I don't need the Users and permissions tables anymore:
Username and Branch_name.

Then, the following DAX that I found did it:

[Data_table_branch_column]
    IN CALCULATETABLE (
        VALUES ( 'bridge_table'[Branch_name] ),
        FILTER (
            ALL ( 'bridge_table' ),
            [Username] = USERNAME ()
                || [Username] = USERPRINCIPALNAME ()
        )
    )

Anonymous
Not applicable

Hello

 

Can I use user permission on the Power BI Desktop (Optimized for Power BI Report Server), if yes how? 

Helpful resources

Announcements
Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!

FebPBI_Carousel

Power BI Monthly Update - February 2025

Check out the February 2025 Power BI update to learn about new features.

Feb2025 NL Carousel

Fabric Community Update - February 2025

Find out what's new and trending in the Fabric community.