// 大名科技(天津)有限公司版权所有 电话:18020030720 QQ:515096995 // // 此源代码遵循位于源代码树根目录中的 LICENSE 文件的许可证 namespace Admin.NET.Core.Service; /// /// 系统用户角色服务 /// public class SysUserRoleService : ITransient { private readonly SqlSugarRepository _sysUserRoleRep; private readonly SysCacheService _sysCacheService; public SysUserRoleService(SqlSugarRepository sysUserRoleRep, SysCacheService sysCacheService) { _sysUserRoleRep = sysUserRoleRep; _sysCacheService = sysCacheService; } /// /// 授权用户角色 /// /// /// public async Task GrantUserRole(UserRoleInput input) { await _sysUserRoleRep.DeleteAsync(u => u.UserId == input.UserId); if (input.RoleIdList == null || input.RoleIdList.Count < 1) return; var roles = input.RoleIdList.Select(u => new SysUserRole { UserId = input.UserId, RoleId = u }).ToList(); await _sysUserRoleRep.InsertRangeAsync(roles); _sysCacheService.Remove(CacheConst.KeyUserButton + input.UserId); } /// /// 根据角色Id删除用户角色 /// /// /// public async Task DeleteUserRoleByRoleId(long roleId) { await _sysUserRoleRep.AsQueryable() .Where(u => u.RoleId == roleId) .Select(u => u.UserId) .ForEachAsync(userId => { _sysCacheService.Remove(CacheConst.KeyUserButton + userId); }); await _sysUserRoleRep.DeleteAsync(u => u.RoleId == roleId); } /// /// 根据用户Id删除用户角色 /// /// /// public async Task DeleteUserRoleByUserId(long userId) { await _sysUserRoleRep.DeleteAsync(u => u.UserId == userId); _sysCacheService.Remove(CacheConst.KeyUserButton + userId); } /// /// 根据用户Id获取角色集合 /// /// /// public async Task> GetUserRoleList(long userId) { var sysUserRoleList = await _sysUserRoleRep.AsQueryable() .Includes(u => u.SysRole) .Where(u => u.UserId == userId).ToListAsync(); return sysUserRoleList.Where(u => u.SysRole != null).Select(u => u.SysRole).ToList(); } /// /// 根据用户Id获取角色Id集合 /// /// /// public async Task> GetUserRoleIdList(long userId) { return await _sysUserRoleRep.AsQueryable() .Where(u => u.UserId == userId).Select(u => u.RoleId).ToListAsync(); } /// /// 根据角色Id获取用户Id集合 /// /// /// public async Task> GetUserIdList(long roleId) { return await _sysUserRoleRep.AsQueryable() .Where(u => u.RoleId == roleId).Select(u => u.UserId).ToListAsync(); } }