分配模块

This commit is contained in:
yubaolee
2017-12-15 17:44:30 +08:00
parent 48db85f686
commit 277676cbba
10 changed files with 76 additions and 110 deletions

View File

@@ -58,7 +58,7 @@ namespace OpenAuth.App
set
{
_user = value;
_userRoleIds = UnitWork.Find<Relevance>(u => u.FirstId == _user.Id && u.Key == "UserRole").Select(u => u.SecondId).ToList();
_userRoleIds = UnitWork.Find<Relevance>(u => u.FirstId == _user.Id && u.Key == Define.USERROLE).Select(u => u.SecondId).ToList();
}
}

View File

@@ -2,6 +2,7 @@
{
public static class Define
{
public static string USERROLE = "UserRole"; //用户角色关联KEY
public const string ROLERESOURCE= "RoleResource"; //角色资源关联KEY
public const string USERRESOURCE = "UserResource"; //用户资源关联KEY
public const string USERORG = "UserOrg"; //用户机构关联KEY

View File

@@ -6,6 +6,7 @@ namespace OpenAuth.App
{
public class ModuleManagerApp :BaseApp<Module>
{
public RevelanceManagerApp RevelanceManagerApp { get; set; }
public void Add(Module model)
{
ChangeModuleCascade(model);
@@ -25,18 +26,25 @@ namespace OpenAuth.App
/// TODO:这里会加载用户及用户角色的所有模块,“为用户分配模块”功能会给人一种混乱的感觉,但可以接受
/// </summary>
/// <param name="userId">The user unique identifier.</param>
public List<Module> LoadForUser(string userId)
public IEnumerable<Module> LoadForUser(string userId)
{
return null;
var roleIds = RevelanceManagerApp.Get(Define.USERROLE, true, userId);
var moduleIds = UnitWork.Find<Relevance>(
u =>
(u.FirstId == userId && u.Key == Define.USERMODULE) ||
(u.Key == Define.ROLEMODULE && roleIds.Contains(u.FirstId))).Select(u => u.SecondId);
return UnitWork.Find<Module>(u => moduleIds.Contains(u.Id)).OrderBy(u => u.SortNo);
}
/// <summary>
/// 加载特定角色的模块
/// </summary>
/// <param name="roleId">The role unique identifier.</param>
public List<Module> LoadForRole(string roleId)
public IEnumerable<Module> LoadForRole(string roleId)
{
return null;
var moduleIds = UnitWork.Find<Relevance>(u => u.FirstId == roleId && u.Key == Define.ROLEMODULE)
.Select(u => u.SecondId);
return UnitWork.Find<Module>(u => moduleIds.Contains(u.Id)).OrderBy(u => u.SortNo);
}
#endregion /

View File

@@ -68,7 +68,7 @@ namespace OpenAuth.App
{
//用户角色
var userRoleIds =
UnitWork.Find<Relevance>(u => u.FirstId == userId && u.Key == "UserRole").Select(u => u.SecondId).ToList();
UnitWork.Find<Relevance>(u => u.FirstId == userId && u.Key == Define.USERROLE).Select(u => u.SecondId).ToList();
//用户角色与自己分配到的角色ID
var moduleIds =