// 大名科技(天津)有限公司版权所有 电话: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();
}
}