调整为Sqlsugar

This commit is contained in:
yubaolee
2026-05-24 21:28:25 +08:00
parent 684b6e0fea
commit 237fc49f2f

View File

@@ -3,13 +3,12 @@ using System.Linq;
using Infrastructure;
using OpenAuth.App.Interface;
using OpenAuth.App.Request;
using OpenAuth.Repository;
using OpenAuth.Repository.Domain;
using OpenAuth.Repository.Interface;
using SqlSugar;
namespace OpenAuth.App
{
public class ModuleManagerApp : BaseTreeApp<Module,OpenAuthDBContext>
public class ModuleManagerApp : SqlSugarBaseTreeApp<Module>
{
private RevelanceManagerApp _revelanceApp;
@@ -23,7 +22,7 @@ namespace OpenAuth.App
CaculateCascade(model);
Repository.Add(model);
Repository.Insert(model);
AddDefaultMenus(model);
//当前登录用户的所有角色自动分配模块
@@ -52,9 +51,9 @@ namespace OpenAuth.App
/// <param name="roleId">The role unique identifier.</param>
public IEnumerable<Module> LoadForRole(string roleId)
{
var moduleIds = UnitWork.Find<Relevance>(u => u.FirstId == roleId && u.RelKey == Define.ROLEMODULE)
.Select(u => u.SecondId);
return UnitWork.Find<Module>(u => moduleIds.Contains(u.Id)).OrderBy(u => u.SortNo);
var moduleIds = SugarClient.Queryable<Relevance>().Where(u => u.FirstId == roleId && u.RelKey == Define.ROLEMODULE)
.Select(u => u.SecondId).ToArray();
return SugarClient.Queryable<Module>().Where(u => moduleIds.Contains(u.Id)).OrderBy(u => u.SortNo).ToList();
}
//获取角色可访问的模块字段
@@ -68,14 +67,14 @@ namespace OpenAuth.App
/// </summary>
public IEnumerable<ModuleElement> LoadMenusForRole(string moduleId, string roleId)
{
var elementIds = _revelanceApp.Get(Define.ROLEELEMENT, true, roleId);
var query = UnitWork.Find<ModuleElement>(u => elementIds.Contains(u.Id));
var elementIds = _revelanceApp.Get(Define.ROLEELEMENT, true, roleId).ToArray();
var query = SugarClient.Queryable<ModuleElement>().Where(u => elementIds.Contains(u.Id));
if (!string.IsNullOrEmpty(moduleId))
{
query = query.Where(u => u.ModuleId == moduleId);
}
return query;
return query.ToList();
}
#endregion /
@@ -87,9 +86,9 @@ namespace OpenAuth.App
/// <returns></returns>
public IEnumerable<SysPrinterPlan> LoadPrinterPlans(string moduleId)
{
var planids = _revelanceApp.Get(Define.MODULEPRINTERPLAN, true, moduleId);
var query = UnitWork.Find<SysPrinterPlan>(u => planids.Contains(u.Id));
return query;
var planids = _revelanceApp.Get(Define.MODULEPRINTERPLAN, true, moduleId).ToArray();
var query = SugarClient.Queryable<SysPrinterPlan>().Where(u => planids.Contains(u.Id));
return query.ToList();
}
/// <summary>
@@ -99,9 +98,9 @@ namespace OpenAuth.App
/// <returns></returns>
public IEnumerable<FlowScheme> LoadFlowSchemes(string moduleId)
{
var planids = _revelanceApp.Get(Define.MODULE_FLOWSCHEME, true, moduleId);
var query = UnitWork.Find<FlowScheme>(u => planids.Contains(u.Id));
return query;
var planids = _revelanceApp.Get(Define.MODULE_FLOWSCHEME, true, moduleId).ToArray();
var query = SugarClient.Queryable<FlowScheme>().Where(u => planids.Contains(u.Id));
return query.ToList();
}
@@ -113,8 +112,7 @@ namespace OpenAuth.App
/// <param name="ids"></param>
public void DelMenu(string[] ids)
{
UnitWork.Delete<ModuleElement>(u => ids.Contains(u.Id));
UnitWork.Save();
SugarClient.Deleteable<ModuleElement>().Where(u => ids.Contains(u.Id)).ExecuteCommand();
}
@@ -130,28 +128,29 @@ namespace OpenAuth.App
throw new CommonException("登录已过期", Define.INVALID_TOKEN);
}
UnitWork.ExecuteWithTransaction(() =>
SugarClient.Ado.BeginTran();
if (model.KeyIsNull())
{
UnitWork.Add(model);
model.GenerateDefaultKeyVal();
}
SugarClient.Insertable(model).ExecuteCommand();
//当前登录用户的所有角色自动分配菜单
loginContext.Roles.ForEach(u =>
//当前登录用户的所有角色自动分配菜单
loginContext.Roles.ForEach(u =>
{
_revelanceApp.Assign(new AssignReq
{
_revelanceApp.Assign(new AssignReq
{
type = Define.ROLEELEMENT,
firstId = u.Id,
secIds = new[] {model.Id}
});
type = Define.ROLEELEMENT,
firstId = u.Id,
secIds = new[] {model.Id}
});
UnitWork.Save();
});
SugarClient.Ado.CommitTran();
}
public void UpdateMenu(ModuleElement model)
{
UnitWork.Update<ModuleElement>(model);
UnitWork.Save();
SugarClient.Updateable(model).ExecuteCommand();
}
//添加默认按钮
@@ -197,8 +196,8 @@ namespace OpenAuth.App
#endregion
public ModuleManagerApp(IUnitWork<OpenAuthDBContext> unitWork, IRepository<Module,OpenAuthDBContext> repository
, RevelanceManagerApp app, IAuth auth) : base(unitWork, repository, auth)
public ModuleManagerApp(ISqlSugarClient client
, RevelanceManagerApp app, IAuth auth) : base(client, auth)
{
_revelanceApp = app;
}