我最近扩展了AspNetRoles模型,以包括一个名为ApplicationId的额外字段。目的是使我可以使用相同的角色名称,但具有不同的ApplicationId。
public class AspApplicationRoles : IdentityRole
{
public AspApplicationRoles() : base() { }
public AspApplicationRoles(String Name) : base(Name) { }
[Required]
public String ApplicationId { get; set; }
public AspNetApplications Application { get; set; }
}
我还在我的IdentityConfig区域中添加了一个OnModelCreating函数,该函数禁用了Name字段上的唯一键。
然后我也像这样更新验证器:
public class ApplicationRoleValidator<TRole> : RoleValidator<TRole> where TRole : AspApplicationRoles
{
private RoleManager<TRole, string> Manager { get; set; }
private AspApplicationRoles data = new AspApplicationRoles();
private ApplicationDbContext dbContext = new ApplicationDbContext();
public ApplicationRoleValidator(RoleManager<TRole, string> manager) : base(manager)
{
Manager = manager;
}
public override async Task<IdentityResult> ValidateAsync(TRole Input)
{
data = dbContext.AspApplicationRoles.Where(ar => ar.ApplicationId == Input.ApplicationId && ar.Name == Input.Name).SingleOrDefault();
if (data == null)
{
return IdentityResult.Success;
}
else
{
return IdentityResult.Failed("Role already exists");
}
}
}
}
但是,当我调试并运行以下行时:var res = manager.Create(role);
它会返回res.Succeeded,但不会将角色名称添加到我的表中。
是否可以扩展或更改create函数?
编辑:
这是“身份”中的“创建”部分
//
// Summary:
// Create a role
//
// Parameters:
// manager:
//
// role:
public static IdentityResult Create<TRole, TKey>(this RoleManager<TRole, TKey> manager, TRole role)
where TRole : class, IRole<TKey>
where TKey : IEquatable<TKey>;