2025-12-17 11:12:13 +08:00
|
|
|
|
using YD_Event.Application.Role.Dtos;
|
2025-12-17 10:32:52 +08:00
|
|
|
|
|
2025-12-17 11:12:13 +08:00
|
|
|
|
namespace YD_Event.Application.Role;
|
2025-12-17 10:32:52 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 角色管理
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public class SysRoleService : BaseService<SysRole>
|
|
|
|
|
|
{
|
|
|
|
|
|
private readonly ISqlSugarRepository<SysRole> _sysRoleRepository;
|
|
|
|
|
|
private readonly ISqlSugarRepository<SysRoleMenu> _sysRoleMenuRepository;
|
|
|
|
|
|
private readonly IEasyCachingProvider _easyCachingProvider;
|
|
|
|
|
|
private readonly IIdGenerator _idGenerator;
|
|
|
|
|
|
|
|
|
|
|
|
public SysRoleService(ISqlSugarRepository<SysRole> sysRoleRepository,
|
|
|
|
|
|
ISqlSugarRepository<SysRoleMenu> sysRoleMenuRepository,
|
|
|
|
|
|
IEasyCachingProvider easyCachingProvider,
|
|
|
|
|
|
IIdGenerator idGenerator) : base(sysRoleRepository)
|
|
|
|
|
|
{
|
|
|
|
|
|
_sysRoleRepository = sysRoleRepository;
|
|
|
|
|
|
_sysRoleMenuRepository = sysRoleMenuRepository;
|
|
|
|
|
|
_easyCachingProvider = easyCachingProvider;
|
|
|
|
|
|
_idGenerator = idGenerator;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 角色分页查询
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="dto"></param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
[HttpGet]
|
|
|
|
|
|
public async Task<PageResult<SysRolePageOutput>> Page([FromQuery] SysRoleQueryInput dto)
|
|
|
|
|
|
{
|
|
|
|
|
|
return await _sysRoleRepository.AsQueryable()
|
|
|
|
|
|
.WhereIF(!string.IsNullOrWhiteSpace(dto.Name), x => x.Name.Contains(dto.Name))
|
|
|
|
|
|
.OrderBy(x => x.Sort)
|
|
|
|
|
|
.OrderByDescending(x => x.Id)
|
|
|
|
|
|
.Select(x => new SysRolePageOutput
|
|
|
|
|
|
{
|
|
|
|
|
|
Id = x.Id,
|
|
|
|
|
|
Name = x.Name,
|
|
|
|
|
|
CreatedTime = x.CreatedTime,
|
|
|
|
|
|
Status = x.Status,
|
|
|
|
|
|
Code = x.Code,
|
|
|
|
|
|
Sort = x.Sort,
|
|
|
|
|
|
Remark = x.Remark
|
|
|
|
|
|
}).ToPagedListAsync(dto);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 添加角色
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="dto"></param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
[Description("添加角色")]
|
|
|
|
|
|
[HttpPost("add")]
|
|
|
|
|
|
[UnitOfWork]
|
|
|
|
|
|
public async Task AddRole(AddSysRoleInput dto)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (await _sysRoleRepository.IsAnyAsync(x => x.Code == dto.Code))
|
|
|
|
|
|
{
|
|
|
|
|
|
throw Oops.Bah("角色编码已存在");
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var role = dto.Adapt<SysRole>();
|
|
|
|
|
|
role.Id = _idGenerator.NewLong();
|
|
|
|
|
|
var roleMenus = dto.Menus.Select(x => new SysRoleMenu()
|
|
|
|
|
|
{
|
|
|
|
|
|
MenuId = x,
|
|
|
|
|
|
RoleId = role.Id
|
|
|
|
|
|
}).ToList();
|
|
|
|
|
|
await _sysRoleRepository.InsertAsync(role);
|
|
|
|
|
|
await _sysRoleMenuRepository.InsertRangeAsync(roleMenus);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 更新角色
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="dto"></param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
[Description("更新角色")]
|
|
|
|
|
|
[HttpPut("edit")]
|
|
|
|
|
|
[UnitOfWork]
|
|
|
|
|
|
public async Task UpdateRole(UpdateSysRoleInput dto)
|
|
|
|
|
|
{
|
|
|
|
|
|
var sysRole = await _sysRoleRepository.GetByIdAsync(dto.Id);
|
|
|
|
|
|
if (sysRole == null)
|
|
|
|
|
|
{
|
|
|
|
|
|
throw Oops.Bah("无效参数");
|
|
|
|
|
|
}
|
|
|
|
|
|
if (await _sysRoleRepository.IsAnyAsync(x => x.Id != dto.Id && x.Code == dto.Code))
|
|
|
|
|
|
{
|
|
|
|
|
|
throw Oops.Bah("角色编码已存在");
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
dto.Adapt(sysRole);
|
|
|
|
|
|
var roleMenus = dto.Menus.Select(x => new SysRoleMenu()
|
|
|
|
|
|
{
|
|
|
|
|
|
MenuId = x,
|
|
|
|
|
|
RoleId = sysRole.Id
|
|
|
|
|
|
}).ToList();
|
|
|
|
|
|
await _sysRoleRepository.UpdateAsync(sysRole);
|
|
|
|
|
|
await _sysRoleMenuRepository.DeleteAsync(x => x.RoleId == sysRole.Id);
|
|
|
|
|
|
await _sysRoleMenuRepository.InsertRangeAsync(roleMenus);
|
|
|
|
|
|
await _easyCachingProvider.RemoveByPrefixAsync(CacheConst.PermissionKey);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 获取角色可访问的菜单和按钮id
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="id">角色id</param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
[Description("获取角色可访问的菜单和按钮id")]
|
|
|
|
|
|
[HttpGet("getRuleMenu")]
|
|
|
|
|
|
public async Task<List<long>> GetRuleMenu([FromQuery] long id)
|
|
|
|
|
|
{
|
|
|
|
|
|
return await _sysRoleRepository.AsQueryable().InnerJoin<SysRoleMenu>((role, roleMenu) => role.Id == roleMenu.RoleId)
|
|
|
|
|
|
.InnerJoin<SysMenu>((role, roleMenu, menu) => roleMenu.MenuId == menu.Id)
|
|
|
|
|
|
.Where((role, roleMenu, menu) => role.Id == id && menu.Status == AvailabilityStatus.Enable)
|
|
|
|
|
|
.Select((role, roleMenu) => roleMenu.MenuId).ToListAsync();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 修改角色状态
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="dto"></param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
[Description("修改角色状态"), HttpPut("setStatus")]
|
|
|
|
|
|
public override async Task SetStatus(AvailabilityDto dto)
|
|
|
|
|
|
{
|
|
|
|
|
|
await base.SetStatus(dto);
|
|
|
|
|
|
await _easyCachingProvider.RemoveByPrefixAsync(CacheConst.PermissionKey);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 删除角色
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="dto"></param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
[Description("删除角色"), HttpDelete("delete")]
|
|
|
|
|
|
public override async Task Delete(KeyDto dto)
|
|
|
|
|
|
{
|
|
|
|
|
|
await base.Delete(dto);
|
|
|
|
|
|
await _easyCachingProvider.RemoveByPrefixAsync(CacheConst.PermissionKey);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 角色下拉选项
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
[Description("角色下拉选项")]
|
|
|
|
|
|
[HttpGet]
|
|
|
|
|
|
public async Task<List<SelectOutput>> RoleSelect()
|
|
|
|
|
|
{
|
|
|
|
|
|
return await _sysRoleRepository.AsQueryable().Where(x => x.Status == AvailabilityStatus.Enable)
|
|
|
|
|
|
.OrderBy(x => x.Sort)
|
|
|
|
|
|
.OrderBy(x => x.Id)
|
|
|
|
|
|
.Select(x => new SelectOutput()
|
|
|
|
|
|
{
|
|
|
|
|
|
Value = x.Id,
|
|
|
|
|
|
Label = x.Name
|
|
|
|
|
|
}).ToListAsync();
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|