mirror of
https://gitee.com/dotnetchina/OpenAuth.Net.git
synced 2025-07-15 23:13:40 +08:00
Routine update
This commit is contained in:
parent
e8b3a0a8cd
commit
e4f4c03389
@ -20,19 +20,19 @@ namespace OpenAuth.App
|
||||
/// <summary>
|
||||
/// 加载一个部门及子部门全部Modules
|
||||
/// </summary>
|
||||
public dynamic Load(int orgId, int pageindex, int pagesize)
|
||||
public dynamic Load(int parentId, int pageindex, int pagesize)
|
||||
{
|
||||
IEnumerable<Module> Modules;
|
||||
int total = 0;
|
||||
if (orgId == 0)
|
||||
if (parentId == 0)
|
||||
{
|
||||
Modules = _repository.LoadModules(pageindex, pagesize);
|
||||
total = _repository.GetCount();
|
||||
}
|
||||
else
|
||||
{
|
||||
Modules = _repository.LoadInOrgs(pageindex, pagesize,GetSubOrgIds(orgId));
|
||||
total = _repository.GetModuleCntInOrgs(orgId);
|
||||
Modules = _repository.LoadInOrgs(pageindex, pagesize, GetSubOrgIds(parentId));
|
||||
total = _repository.GetModuleCntInOrgs(parentId);
|
||||
}
|
||||
|
||||
return new
|
||||
@ -91,31 +91,9 @@ namespace OpenAuth.App
|
||||
public void AddOrUpdate(Module model)
|
||||
{
|
||||
Module module = model;
|
||||
ChangeModuleCascade(module);
|
||||
if (module.Id == 0)
|
||||
{
|
||||
string cascadeId;
|
||||
int currentCascadeId = GetMaxCascadeId(module.ParentId);
|
||||
|
||||
if (module.ParentId != 0)
|
||||
{
|
||||
var parentOrg = _repository.FindSingle(o => o.Id == module.ParentId);
|
||||
if (parentOrg != null)
|
||||
{
|
||||
cascadeId = parentOrg.CascadeId + "." + currentCascadeId;
|
||||
module.ParentName = parentOrg.Name;
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new Exception("未能找到该组织的父节点信息");
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
cascadeId = "0." + currentCascadeId;
|
||||
module.ParentName = "";
|
||||
}
|
||||
|
||||
module.CascadeId = cascadeId;
|
||||
_repository.Add(module);
|
||||
}
|
||||
else
|
||||
@ -125,6 +103,8 @@ namespace OpenAuth.App
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
#region 私有方法
|
||||
|
||||
//根据同一级中最大的语义ID
|
||||
@ -143,11 +123,39 @@ namespace OpenAuth.App
|
||||
|
||||
private int[] GetSubOrgIds(int orgId)
|
||||
{
|
||||
var org = _repository.FindSingle(u => u.Id == orgId);
|
||||
var orgs = _repository.Find(u => u.CascadeId.Contains(org.CascadeId)).Select(u => u.Id).ToArray();
|
||||
var parent = _repository.FindSingle(u => u.Id == orgId);
|
||||
var orgs = _repository.Find(u => u.CascadeId.Contains(parent.CascadeId)).Select(u => u.Id).ToArray();
|
||||
return orgs;
|
||||
}
|
||||
|
||||
//修改对象的级联ID
|
||||
private void ChangeModuleCascade(Module module)
|
||||
{
|
||||
string cascadeId;
|
||||
int currentCascadeId = GetMaxCascadeId(module.ParentId);
|
||||
|
||||
if (module.ParentId != 0)
|
||||
{
|
||||
var parentOrg = _repository.FindSingle(o => o.Id == module.ParentId);
|
||||
if (parentOrg != null)
|
||||
{
|
||||
cascadeId = parentOrg.CascadeId + "." + currentCascadeId;
|
||||
module.ParentName = parentOrg.Name;
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new Exception("未能找到该组织的父节点信息");
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
cascadeId = "0." + currentCascadeId;
|
||||
module.ParentName = "";
|
||||
}
|
||||
|
||||
module.CascadeId = cascadeId;
|
||||
}
|
||||
|
||||
#endregion 私有方法
|
||||
|
||||
}
|
||||
|
@ -57,6 +57,47 @@ namespace OpenAuth.UnitTest
|
||||
//
|
||||
#endregion
|
||||
|
||||
//初始化导航
|
||||
[TestMethod]
|
||||
public void InitNav()
|
||||
{
|
||||
var root = new Module()
|
||||
{
|
||||
Name = "基础设置",
|
||||
ParentId = 0
|
||||
};
|
||||
_app.AddOrUpdate(root);
|
||||
|
||||
var module = new Module
|
||||
{
|
||||
Name = "模块管理",
|
||||
Url = "ModuleManager/Index",
|
||||
ParentId = root.Id
|
||||
};
|
||||
_app.AddOrUpdate(module);
|
||||
module = new Module
|
||||
{
|
||||
Name = "用户管理",
|
||||
Url = "UserManager/Index",
|
||||
ParentId = root.Id
|
||||
};
|
||||
_app.AddOrUpdate(module);
|
||||
module = new Module
|
||||
{
|
||||
Name = "角色管理",
|
||||
Url = "RoleManager/Index",
|
||||
ParentId = root.Id
|
||||
};
|
||||
_app.AddOrUpdate(module);
|
||||
module = new Module
|
||||
{
|
||||
Name = "机构管理",
|
||||
Url = "OrgManager/Index",
|
||||
ParentId = root.Id
|
||||
};
|
||||
_app.AddOrUpdate(module);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void TestAddModule()
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user