SysRoleController.cs 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. using Attribute;
  2. using Common;
  3. using Dto;
  4. using Enums;
  5. using Extensions;
  6. using Filters;
  7. using Infrastructure;
  8. using Infrastructure.Model;
  9. using Mapster;
  10. using Microsoft.AspNetCore.Mvc;
  11. using Middleware;
  12. using Model;
  13. using Model.Base;
  14. using Services;
  15. namespace Controllers
  16. {
  17. /// <summary>
  18. /// 角色信息
  19. /// </summary>
  20. [Verify]
  21. [Route("system/role")]
  22. [ApiExplorerSettings(GroupName = "sys")]
  23. public class SysRoleController : BaseController
  24. {
  25. private readonly ISysRoleService sysRoleService;
  26. private readonly ISysMenuService sysMenuService;
  27. public SysRoleController(
  28. ISysRoleService sysRoleService,
  29. ISysMenuService sysMenuService)
  30. {
  31. this.sysRoleService = sysRoleService;
  32. this.sysMenuService = sysMenuService;
  33. }
  34. /// <summary>
  35. /// 获取系统角色管理
  36. /// </summary>
  37. /// <returns></returns>
  38. [ActionPermissionFilter(Permission = "system:role:list")]
  39. [HttpGet("list")]
  40. public IActionResult List([FromQuery] SysRole role, [FromQuery] PagerInfo pager)
  41. {
  42. var list = sysRoleService.SelectRoleList(role, pager);
  43. return SUCCESS(list, TIME_FORMAT_FULL);
  44. }
  45. /// <summary>
  46. /// 根据角色编号获取详细信息
  47. /// </summary>
  48. /// <param name="roleId"></param>
  49. /// <returns></returns>
  50. [HttpGet("{roleId}")]
  51. public IActionResult GetInfo(long roleId = 0)
  52. {
  53. var info = sysRoleService.SelectRoleById(roleId);
  54. return SUCCESS(info, TIME_FORMAT_FULL);
  55. }
  56. /// <summary>
  57. /// 添加角色
  58. /// </summary>
  59. /// <param name="dto"></param>
  60. /// <returns></returns>
  61. [HttpPost]
  62. [ActionPermissionFilter(Permission = "system:role:add")]
  63. [Log(Title = "角色管理", BusinessType = BusinessType.INSERT)]
  64. [Route("edit")]
  65. public IActionResult RoleAdd([FromBody] SysRoleDto dto)
  66. {
  67. if (dto == null) return ToResponse(ApiResult.Error(101, "请求参数错误"));
  68. SysRole sysRoleDto = dto.Adapt<SysRole>();
  69. if (UserConstants.NOT_UNIQUE.Equals(sysRoleService.CheckRoleKeyUnique(sysRoleDto)))
  70. {
  71. return ToResponse(ApiResult.Error((int)ResultCode.CUSTOM_ERROR, $"新增角色'{sysRoleDto.RoleName}'失败,角色权限已存在"));
  72. }
  73. sysRoleDto.CreateBy = HttpContext.GetName();
  74. long roleId = sysRoleService.InsertRole(sysRoleDto);
  75. return ToResponse(roleId);
  76. }
  77. /// <summary>
  78. /// 修改角色
  79. /// </summary>
  80. /// <param name="dto"></param>
  81. /// <returns></returns>
  82. [HttpPut]
  83. [ActionPermissionFilter(Permission = "system:role:edit")]
  84. [Log(Title = "角色管理", BusinessType = BusinessType.UPDATE)]
  85. [Route("edit")]
  86. public IActionResult RoleEdit([FromBody] SysRoleDto dto)
  87. {
  88. if (dto == null || dto.RoleId <= 0 || string.IsNullOrEmpty(dto.RoleKey))
  89. {
  90. return ToResponse(ApiResult.Error(101, "请求参数错误"));
  91. }
  92. SysRole sysRoleDto = dto.Adapt<SysRole>();
  93. sysRoleService.CheckRoleAllowed(sysRoleDto);
  94. var info = sysRoleService.SelectRoleById(sysRoleDto.RoleId);
  95. if (info != null && info.RoleCode != sysRoleDto.RoleCode)
  96. {
  97. if (UserConstants.NOT_UNIQUE.Equals(sysRoleService.CheckRoleKeyUnique(sysRoleDto)))
  98. {
  99. return ToResponse(ApiResult.Error($"编辑角色'{sysRoleDto.RoleName}'失败,角色权限已存在"));
  100. }
  101. }
  102. sysRoleDto.UpdateBy = HttpContext.GetName();
  103. int upResult = sysRoleService.UpdateRole(sysRoleDto);
  104. if (upResult > 0)
  105. {
  106. return SUCCESS(upResult);
  107. }
  108. return ToResponse(ApiResult.Error($"修改角色'{sysRoleDto.RoleName}'失败,请联系管理员"));
  109. }
  110. /// <summary>
  111. /// 根据角色分配菜单
  112. /// </summary>
  113. /// <param name="sysRoleDto"></param>
  114. /// <returns></returns>
  115. [HttpPut("dataScope")]
  116. [ActionPermissionFilter(Permission = "system:role:authorize")]
  117. [Log(Title = "角色管理", BusinessType = BusinessType.UPDATE)]
  118. public IActionResult DataScope([FromBody] SysRoleDto sysRoleDto)
  119. {
  120. if (sysRoleDto == null || sysRoleDto.RoleId <= 0) return ToResponse(ApiResult.Error(101, "请求参数错误"));
  121. SysRole sysRole = sysRoleDto.Adapt<SysRole>();
  122. sysRoleDto.CreateBy = HttpContext.GetName();
  123. sysRoleService.CheckRoleAllowed(sysRole);
  124. bool result = sysRoleService.AuthDataScope(sysRoleDto);
  125. return SUCCESS(result);
  126. }
  127. /// <summary>
  128. /// 角色删除
  129. /// </summary>
  130. /// <param name="roleId"></param>
  131. /// <returns></returns>
  132. [HttpDelete("{roleId}")]
  133. [Log(Title = "角色管理", BusinessType = BusinessType.DELETE)]
  134. [ActionPermissionFilter(Permission = "system:role:remove")]
  135. public IActionResult Remove(string roleId)
  136. {
  137. long[] roleIds = Tools.SpitLongArrary(roleId);
  138. int result = sysRoleService.DeleteRoleByRoleId(roleIds);
  139. return ToResponse(result);
  140. }
  141. /// <summary>
  142. /// 修改角色状态
  143. /// </summary>
  144. /// <param name="roleDto">角色对象</param>
  145. /// <returns></returns>
  146. [HttpPut("changeStatus")]
  147. [Log(Title = "修改角色状态", BusinessType = BusinessType.UPDATE)]
  148. [ActionPermissionFilter(Permission = "system:role:edit")]
  149. public IActionResult ChangeStatus([FromBody] SysRole roleDto)
  150. {
  151. sysRoleService.CheckRoleAllowed(roleDto);
  152. int result = sysRoleService.UpdateRoleStatus(roleDto);
  153. return ToResponse(result);
  154. }
  155. /// <summary>
  156. /// 角色导出
  157. /// </summary>
  158. /// <returns></returns>
  159. [Log(BusinessType = BusinessType.EXPORT, IsSaveResponseData = false, Title = "角色导出")]
  160. [HttpGet("export")]
  161. [ActionPermissionFilter(Permission = "system:role:export")]
  162. public IActionResult Export()
  163. {
  164. var list = sysRoleService.SelectRoleAll();
  165. string sFileName = ExportExcel(list, "sysrole", "角色");
  166. return SUCCESS(new { path = "/export/" + sFileName, fileName = sFileName });
  167. }
  168. /// <summary>
  169. /// 导出角色菜单
  170. /// </summary>
  171. /// <param name="roleId"></param>
  172. /// <returns></returns>
  173. [Log(BusinessType = BusinessType.EXPORT, IsSaveResponseData = false, Title = "角色菜单导出")]
  174. [HttpGet("exportRoleMenu")]
  175. [ActionPermissionFilter(Permission = "system:role:export")]
  176. public IActionResult ExportRoleMenu(int roleId)
  177. {
  178. MenuQueryDto dto = new() { DelFlag = "0", MenuTypeIds = "M,C,F" };
  179. var list = sysMenuService.SelectRoleMenuListByRole(dto, roleId);
  180. var result = ExportExcelMini(list, roleId.ToString(), "角色菜单");
  181. return ExportExcel(result.Item2, result.Item1);
  182. }
  183. }
  184. }