mirror of
https://gitee.com/dotnetchina/OpenAuth.Net.git
synced 2025-09-20 02:29:24 +08:00
分配模块
This commit is contained in:
@@ -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 用户/角色分配模块
|
||||
|
Reference in New Issue
Block a user