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();
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.
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.
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");
Try this
string id = UserManager.FindByEmail(model.Email).Id;
IList<string> roleNames=UserManager.GetRoles(id);