12

Before the update of the dll's in the Entity Framework i was able to do this

user.Roles.Where(r => r.Role.Name == "Admin").FisrtOrDefault(); 

Now, i can only do r.RoleId, and i can't find a way to retreive the name of thar Role Id. I'm using this in my controllers and in my AuthorizeAttribute class.

Can someone help me here?

Regards

MarBVI
  • 811
  • 2
  • 12
  • 34

4 Answers4

9

Try this

string id = UserManager.FindByEmail(model.Email).Id;
IList<string> roleNames=UserManager.GetRoles(id);
Neeraj Singh
  • 151
  • 2
  • 6
8

Ask the RoleMananger?

RoleManager.Roles.
// or
RoleManager.FindByIdAsync()
// or 
RoleManager.FindByNameAsync()

You may want to take some time and learn the new security features in Asp.Net Security and Asp.Net Identity.

Erik Philips
  • 53,428
  • 11
  • 128
  • 150
2

I've just had almost exactly the same issue and I solved it like this:

public class UserRole : IdentityUserRole
{
    public virtual Role Role { get; set; } // add this to see roles
    public virtual User User { get; set; } // add this to see users
}

Now your original code user.Roles.Where(r => r.Role.Name == "Admin").FirstOrDefault(); will work, which could be handy if you don't have easy access to the RoleManager for any reason.

Ed Graham
  • 4,306
  • 3
  • 30
  • 30
1

If your aim is to check if a user is in a role you can access it from the IPrincipal.User object in an action

User.IsInRole("Admin");
Phil
  • 1,609
  • 12
  • 24