分配模块

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

@@ -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 /