| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251 |
- // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
- //
- // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
- //
- // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
- namespace Admin.NET.Core.Service;
- /// <summary>
- /// 系统角色服务 🧩
- /// </summary>
- [ApiDescriptionSettings(Order = 480)]
- public class SysRoleService : IDynamicApiController, ITransient
- {
- private readonly UserManager _userManager;
- private readonly SqlSugarRepository<SysRole> _sysRoleRep;
- private readonly SysRoleOrgService _sysRoleOrgService;
- private readonly SysRoleMenuService _sysRoleMenuService;
- private readonly SysOrgService _sysOrgService;
- private readonly SysUserRoleService _sysUserRoleService;
- public SysRoleService(UserManager userManager,
- SqlSugarRepository<SysRole> sysRoleRep,
- SysRoleOrgService sysRoleOrgService,
- SysRoleMenuService sysRoleMenuService,
- SysOrgService sysOrgService,
- SysUserRoleService sysUserRoleService)
- {
- _userManager = userManager;
- _sysRoleRep = sysRoleRep;
- _sysRoleOrgService = sysRoleOrgService;
- _sysRoleMenuService = sysRoleMenuService;
- _sysOrgService = sysOrgService;
- _sysUserRoleService = sysUserRoleService;
- }
- /// <summary>
- /// 获取角色分页列表 🔖
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- [DisplayName("获取角色分页列表")]
- public async Task<SqlSugarPagedList<SysRole>> Page(PageRoleInput input)
- {
- return await _sysRoleRep.AsQueryable()
- .WhereIF(!_userManager.SuperAdmin, u => u.TenantId == _userManager.TenantId) // 若非超管,则只能操作本租户的角色
- .WhereIF(!_userManager.SuperAdmin && !_userManager.SysAdmin, u => u.CreateUserId == _userManager.UserId) // 若非超管且非系统管理员,则只能操作自己创建的角色
- .WhereIF(!string.IsNullOrWhiteSpace(input.Name), u => u.Name.Contains(input.Name))
- .WhereIF(!string.IsNullOrWhiteSpace(input.Code), u => u.Code.Contains(input.Code))
- .OrderBy(u => new { u.OrderNo, u.Id })
- .ToPagedListAsync(input.Page, input.PageSize);
- }
- /// <summary>
- /// 获取角色列表 🔖
- /// </summary>
- /// <returns></returns>
- [DisplayName("获取角色列表")]
- public async Task<List<RoleOutput>> GetList()
- {
- // 当前用户已拥有的角色集合
- var roleIdList = _userManager.SuperAdmin ? new List<long>() : await _sysUserRoleService.GetUserRoleIdList(_userManager.UserId);
- return await _sysRoleRep.AsQueryable()
- .WhereIF(!_userManager.SuperAdmin, u => u.TenantId == _userManager.TenantId) // 若非超管,则只能操作本租户的角色
- .WhereIF(!_userManager.SuperAdmin && !_userManager.SysAdmin, u => u.CreateUserId == _userManager.UserId || roleIdList.Contains(u.Id)) // 若非超管且非系统管理员,则只显示自己创建和已拥有的角色
- .Where(u => u.Status != StatusEnum.Disable) // 非禁用的
- .OrderBy(u => new { u.OrderNo, u.Id }).Select<RoleOutput>().ToListAsync();
- }
- /// <summary>
- /// 增加角色 🔖
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- [ApiDescriptionSettings(Name = "Add"), HttpPost]
- [DisplayName("增加角色")]
- public async Task AddRole(AddRoleInput input)
- {
- if (await _sysRoleRep.IsAnyAsync(u => u.Name == input.Name && u.Code == input.Code))
- throw Oops.Oh(ErrorCodeEnum.D1006);
- var newRole = await _sysRoleRep.AsInsertable(input.Adapt<SysRole>()).ExecuteReturnEntityAsync();
- input.Id = newRole.Id;
- await UpdateRoleMenu(input);
- }
- /// <summary>
- /// 更新角色菜单权限
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- private async Task UpdateRoleMenu(AddRoleInput input)
- {
- if (input.MenuIdList == null || input.MenuIdList.Count < 1)
- return;
- // 将父节点为0的菜单排除,防止前端全选异常
- var pMenuIds = await _sysRoleRep.ChangeRepository<SqlSugarRepository<SysMenu>>().AsQueryable().Where(u => input.MenuIdList.Contains(u.Id) && u.Pid == 0).ToListAsync(u => u.Id);
- var menuIds = input.MenuIdList.Except(pMenuIds); // 差集
- await GrantMenu(new RoleMenuInput()
- {
- Id = input.Id,
- MenuIdList = menuIds.ToList()
- });
- }
- /// <summary>
- /// 更新角色 🔖
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- [ApiDescriptionSettings(Name = "Update"), HttpPost]
- [DisplayName("更新角色")]
- public async Task UpdateRole(UpdateRoleInput input)
- {
- if (await _sysRoleRep.IsAnyAsync(u => u.Name == input.Name && u.Code == input.Code && u.Id != input.Id))
- throw Oops.Oh(ErrorCodeEnum.D1006);
- await _sysRoleRep.AsUpdateable(input.Adapt<SysRole>()).IgnoreColumns(true)
- .IgnoreColumns(u => new { u.DataScope }).ExecuteCommandAsync();
- await UpdateRoleMenu(input);
- }
- /// <summary>
- /// 删除角色 🔖
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- [UnitOfWork]
- [ApiDescriptionSettings(Name = "Delete"), HttpPost]
- [DisplayName("删除角色")]
- public async Task DeleteRole(DeleteRoleInput input)
- {
- // 禁止删除系统管理员角色
- var sysRole = await _sysRoleRep.GetFirstAsync(u => u.Id == input.Id) ?? throw Oops.Oh(ErrorCodeEnum.D1002);
- if (sysRole.Code == CommonConst.SysAdminRole)
- throw Oops.Oh(ErrorCodeEnum.D1019);
- // 若角色有用户则禁止删除
- var userIds = await _sysUserRoleService.GetUserIdList(input.Id);
- if (userIds != null && userIds.Count > 0)
- throw Oops.Oh(ErrorCodeEnum.D1025);
- await _sysRoleRep.DeleteAsync(sysRole);
- // 级联删除角色机构数据
- await _sysRoleOrgService.DeleteRoleOrgByRoleId(sysRole.Id);
- // 级联删除用户角色数据
- await _sysUserRoleService.DeleteUserRoleByRoleId(sysRole.Id);
- // 级联删除角色菜单数据
- await _sysRoleMenuService.DeleteRoleMenuByRoleId(sysRole.Id);
- }
- /// <summary>
- /// 授权角色菜单 🔖
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- [UnitOfWork]
- [DisplayName("授权角色菜单")]
- public async Task GrantMenu(RoleMenuInput input)
- {
- await _sysRoleMenuService.GrantRoleMenu(input);
- }
- /// <summary>
- /// 授权角色数据范围 🔖
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- [UnitOfWork]
- [DisplayName("授权角色数据范围")]
- public async Task GrantDataScope(RoleOrgInput input)
- {
- // 删除与该角色相关的用户机构缓存
- var userIdList = await _sysUserRoleService.GetUserIdList(input.Id);
- foreach (var userId in userIdList)
- {
- SqlSugarFilter.DeleteUserOrgCache(userId, _sysRoleRep.Context.CurrentConnectionConfig.ConfigId.ToString());
- }
- var role = await _sysRoleRep.GetFirstAsync(u => u.Id == input.Id);
- var dataScope = input.DataScope;
- if (!_userManager.SuperAdmin)
- {
- // 非超级管理员没有全部数据范围权限
- if (dataScope == (int)DataScopeEnum.All)
- throw Oops.Oh(ErrorCodeEnum.D1016);
- // 若数据范围自定义,则判断授权数据范围是否有权限
- if (dataScope == (int)DataScopeEnum.Define)
- {
- var grantOrgIdList = input.OrgIdList;
- if (grantOrgIdList.Count > 0)
- {
- var orgIdList = await _sysOrgService.GetUserOrgIdList();
- if (orgIdList.Count < 1)
- throw Oops.Oh(ErrorCodeEnum.D1016);
- else if (!grantOrgIdList.All(u => orgIdList.Any(c => c == u)))
- throw Oops.Oh(ErrorCodeEnum.D1016);
- }
- }
- }
- role.DataScope = (DataScopeEnum)dataScope;
- await _sysRoleRep.AsUpdateable(role).UpdateColumns(u => new { u.DataScope }).ExecuteCommandAsync();
- await _sysRoleOrgService.GrantRoleOrg(input);
- }
- /// <summary>
- /// 根据角色Id获取菜单Id集合 🔖
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- [DisplayName("根据角色Id获取菜单Id集合")]
- public async Task<List<long>> GetOwnMenuList([FromQuery] RoleInput input)
- {
- return await _sysRoleMenuService.GetRoleMenuIdList(new List<long> { input.Id });
- }
- /// <summary>
- /// 根据角色Id获取机构Id集合 🔖
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- [DisplayName("根据角色Id获取机构Id集合")]
- public async Task<List<long>> GetOwnOrgList([FromQuery] RoleInput input)
- {
- return await _sysRoleOrgService.GetRoleOrgIdList(new List<long> { input.Id });
- }
- /// <summary>
- /// 设置角色状态 🔖
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- [DisplayName("设置角色状态")]
- public async Task<int> SetStatus(RoleInput input)
- {
- if (!Enum.IsDefined(typeof(StatusEnum), input.Status))
- throw Oops.Oh(ErrorCodeEnum.D3005);
- return await _sysRoleRep.AsUpdateable()
- .SetColumns(u => u.Status == input.Status)
- .Where(u => u.Id == input.Id)
- .ExecuteCommandAsync();
- }
- }
|