cancel
Showing results for 
Search instead for 
Did you mean: 
Reply
Highlighted
Advocate II
Advocate II

USERNAME() returning weird e-mail format

I'm using USERNAME() to check against a security table for Row Level Security (RLS) based on the user.  

 

For one of the users, I'm getting a weird e-mail format returned:  live.com#john.doe@outlook.com

Didn't figure this out until I explicitly put USERNAME() in a card on the report to see what was being used.

 

Has anyone seen that?  Is this going to happen for all users that have outlook.com e-mail addresses?  

 

Using the "live.com#john.doe@outlook.com" in my look up table doesn't work, so I'm thinking I have to filter out any text before a # in an e-mail address to correct for this weird behavior.  Any insights to this would help me with configuring my access table for others.

19 REPLIES 19
Highlighted

Hi there

have you test it, where in your dataset you have just the email address?




Did I answer your question? Mark my post as a solution!

Proud to be a Super User!







Power BI Blog

Highlighted

Yes, that's what I've been using.  So what I've done now is replicated the Security Role and use the unaltered USERPRINCIPALNAME() value and put that weird e-mail format into the table to accomodate when that happens.

Highlighted

Ok thanks for letting me know





Did I answer your question? Mark my post as a solution!

Proud to be a Super User!







Power BI Blog

Highlighted

I have the exact same issue. It only started Monday of this week. Prior to that the Username() function did return the email address of the person signed in. A solution to this other than just having to change my file to fit the random UPNs that I get is much needed. 

Highlighted

I would suggest always using the USERPRINCIPALNAME() as that is what is designed for the Power BI Service.

Also I can see that it follows the same convention for each email address, so you could do this in the Power Query Editor.




Did I answer your question? Mark my post as a solution!

Proud to be a Super User!







Power BI Blog

Highlighted

I have tried both and the problem is that neither function returns the correct output. An even bigger problem is that they used to. 

 

From Microsoft's own documentation the show dynamic row level security working as such:

Capture.PNG

 

 

You can see by design, neither function is supposed to return the extra information, allowing you to set something up in rls like [useremail] = UPN(). But that no longer works because of the need to manipulate the email address in the table, since you can't manipulate the UPN without compromising logins. 

 

You could do as OP said and just enter the extra information into your table, but now the old users that are in there behave differently. Their function still returns their email while the newly added users return the extra information. So to keep everyone the same you would need to remove everyone and reinvite so every user UPN() function returns the extra information and then write up the dax to fix the emails to match the UPN() function. 

 

 

Highlighted

I guess you can't put e-mails into the message body.  I just posted a reply that disappeared.  Sucks.

 

So basically, I've determined there are 3 different e-mail formats that get return: 1) regular, 2) live.com# prefix, and 3) abc_workmail.com#EXT#(at)onmail.mail.com

 

It's a pain to figure out which one is going to show up, so I decided to just fix the e-mail back to regular and not have to mess with the special characters inserted.  Here's an example of my formula used in the RLS role:

 

[Region] =
VAR findpound = FIND("#", USERPRINCIPALNAME(), 1, 0)
VAR CleanUserName = MID(USERPRINCIPALNAME(),
    FIND ("#", USERPRINCIPALNAME(), 1, 0) + 1,
          LEN (USERPRINCIPALNAME()) - findpound)
VAR CleanedUserName = IF(LEFT(CleanUserName,4)="EXT#",
    SUBSTITUTE(LEFT(USERPRINCIPALNAME(),
         findpound-1), "_","@"),CleanUserName)
RETURN
LOOKUPVALUE(
   Region[Region],
   Region[Country],
   LOOKUPVALUE(
      ReportUsers[Country],
      ReportUsers[Account],
      CleanedUserName),
   Region[Region],
   [Region]
)

View solution in original post

Highlighted

After a couple of weeks speaking with Microsoft reps, the issue seems to be resolved. The UPN() and UN() function should now return the email of the user rather than the added extension for external users. 

Highlighted

Yes, it looks like they did change the e-mails to show actual e-mails.  Interestingly, one of my external users had an e-mail that was aliasa@company.com and now it shows FirstName.LastName@company.com.  I had to update my access table.  Not sure of what circumstances determine which e-mail will be used.

Highlighted

What is UN mean?




Did I answer your question? Mark my post as a solution!

Proud to be a Super User!







Power BI Blog

Helpful resources

Announcements
Community Conference

Power Platform Community Conference

Check out the on demand sessions that are available now!

Community Conference

Microsoft Power Platform Communities

Check out the Winners!

secondImage

Create an end-to-end data and analytics solution

Learn how Power BI works with the latest Azure data and analytics innovations at the digital event with Microsoft CEO Satya Nadella.

Top Solution Authors
Top Kudoed Authors