SysRoleController.cs 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  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. /// <returns></returns>
  49. [HttpGet("/v1/skb/sysServer/role/list")]
  50. public IActionResult AllList()
  51. {
  52. return SUCCESS(sysRoleService.GetList(), TIME_FORMAT_FULL);
  53. }
  54. /// <summary>
  55. /// 根据角色编号获取详细信息
  56. /// </summary>
  57. /// <param name="roleId"></param>
  58. /// <returns></returns>
  59. [HttpGet("{roleId}")]
  60. public IActionResult GetInfo(long roleId = 0)
  61. {
  62. var info = sysRoleService.SelectRoleById(roleId);
  63. return SUCCESS(info, TIME_FORMAT_FULL);
  64. }
  65. /// <summary>
  66. /// 添加角色
  67. /// </summary>
  68. /// <param name="dto"></param>
  69. /// <returns></returns>
  70. [HttpPost]
  71. [ActionPermissionFilter(Permission = "system:role:add")]
  72. [Log(Title = "角色管理", BusinessType = BusinessType.INSERT)]
  73. [Route("edit")]
  74. public IActionResult RoleAdd([FromBody] SysRoleDto dto)
  75. {
  76. if (dto == null) return ToResponse(ApiResult.Error(101, "请求参数错误"));
  77. SysRole sysRoleDto = dto.Adapt<SysRole>();
  78. if (UserConstants.NOT_UNIQUE.Equals(sysRoleService.CheckRoleKeyUnique(sysRoleDto)))
  79. {
  80. return ToResponse(ApiResult.Error((int)ResultCode.CUSTOM_ERROR, $"新增角色'{sysRoleDto.RoleName}'失败,角色权限已存在"));
  81. }
  82. sysRoleDto.CreateBy = HttpContext.GetName();
  83. long roleId = sysRoleService.InsertRole(sysRoleDto);
  84. return ToResponse(roleId);
  85. }
  86. /// <summary>
  87. /// 修改角色
  88. /// </summary>
  89. /// <param name="dto"></param>
  90. /// <returns></returns>
  91. [HttpPut]
  92. [ActionPermissionFilter(Permission = "system:role:edit")]
  93. [Log(Title = "角色管理", BusinessType = BusinessType.UPDATE)]
  94. [Route("edit")]
  95. public IActionResult RoleEdit([FromBody] SysRoleDto dto)
  96. {
  97. if (dto == null || dto.RoleId <= 0 || string.IsNullOrEmpty(dto.RoleKey))
  98. {
  99. return ToResponse(ApiResult.Error(101, "请求参数错误"));
  100. }
  101. SysRole sysRoleDto = dto.Adapt<SysRole>();
  102. sysRoleService.CheckRoleAllowed(sysRoleDto);
  103. var info = sysRoleService.SelectRoleById(sysRoleDto.RoleId);
  104. if (info != null && info.RoleCode != sysRoleDto.RoleCode)
  105. {
  106. if (UserConstants.NOT_UNIQUE.Equals(sysRoleService.CheckRoleKeyUnique(sysRoleDto)))
  107. {
  108. return ToResponse(ApiResult.Error($"编辑角色'{sysRoleDto.RoleName}'失败,角色权限已存在"));
  109. }
  110. }
  111. sysRoleDto.UpdateBy = HttpContext.GetName();
  112. int upResult = sysRoleService.UpdateRole(sysRoleDto);
  113. if (upResult > 0)
  114. {
  115. return SUCCESS(upResult);
  116. }
  117. return ToResponse(ApiResult.Error($"修改角色'{sysRoleDto.RoleName}'失败,请联系管理员"));
  118. }
  119. /// <summary>
  120. /// 根据角色分配菜单
  121. /// </summary>
  122. /// <param name="sysRoleDto"></param>
  123. /// <returns></returns>
  124. [HttpPut("dataScope")]
  125. [ActionPermissionFilter(Permission = "system:role:authorize")]
  126. [Log(Title = "角色管理", BusinessType = BusinessType.UPDATE)]
  127. public IActionResult DataScope([FromBody] SysRoleDto sysRoleDto)
  128. {
  129. if (sysRoleDto == null || sysRoleDto.RoleId <= 0) return ToResponse(ApiResult.Error(101, "请求参数错误"));
  130. SysRole sysRole = sysRoleDto.Adapt<SysRole>();
  131. sysRoleDto.CreateBy = HttpContext.GetName();
  132. sysRoleService.CheckRoleAllowed(sysRole);
  133. bool result = sysRoleService.AuthDataScope(sysRoleDto);
  134. return SUCCESS(result);
  135. }
  136. /// <summary>
  137. /// 角色删除
  138. /// </summary>
  139. /// <param name="roleId"></param>
  140. /// <returns></returns>
  141. [HttpDelete("{roleId}")]
  142. [Log(Title = "角色管理", BusinessType = BusinessType.DELETE)]
  143. [ActionPermissionFilter(Permission = "system:role:remove")]
  144. public IActionResult Remove(string roleId)
  145. {
  146. long[] roleIds = Tools.SpitLongArrary(roleId);
  147. int result = sysRoleService.DeleteRoleByRoleId(roleIds);
  148. return ToResponse(result);
  149. }
  150. /// <summary>
  151. /// 修改角色状态
  152. /// </summary>
  153. /// <param name="roleDto">角色对象</param>
  154. /// <returns></returns>
  155. [HttpPut("changeStatus")]
  156. [Log(Title = "修改角色状态", BusinessType = BusinessType.UPDATE)]
  157. [ActionPermissionFilter(Permission = "system:role:edit")]
  158. public IActionResult ChangeStatus([FromBody] SysRole roleDto)
  159. {
  160. sysRoleService.CheckRoleAllowed(roleDto);
  161. int result = sysRoleService.UpdateRoleStatus(roleDto);
  162. return ToResponse(result);
  163. }
  164. /// <summary>
  165. /// 角色导出
  166. /// </summary>
  167. /// <returns></returns>
  168. [Log(BusinessType = BusinessType.EXPORT, IsSaveResponseData = false, Title = "角色导出")]
  169. [HttpGet("export")]
  170. [ActionPermissionFilter(Permission = "system:role:export")]
  171. public IActionResult Export()
  172. {
  173. var list = sysRoleService.SelectRoleAll();
  174. string sFileName = ExportExcel(list, "sysrole", "角色");
  175. return SUCCESS(new { path = "/export/" + sFileName, fileName = sFileName });
  176. }
  177. /// <summary>
  178. /// 导出角色菜单
  179. /// </summary>
  180. /// <param name="roleId"></param>
  181. /// <returns></returns>
  182. [Log(BusinessType = BusinessType.EXPORT, IsSaveResponseData = false, Title = "角色菜单导出")]
  183. [HttpGet("exportRoleMenu")]
  184. [ActionPermissionFilter(Permission = "system:role:export")]
  185. public IActionResult ExportRoleMenu(int roleId)
  186. {
  187. MenuQueryDto dto = new() { delFlag = "0", menuTypeIds = "M,C,F" };
  188. var list = sysMenuService.SelectRoleMenuListByRole(dto, roleId);
  189. var result = ExportExcelMini(list, roleId.ToString(), "角色菜单");
  190. return ExportExcel(result.Item2, result.Item1);
  191. }
  192. }
  193. }