SysRoleController.java 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. package com.ruoyi.web.controller.system;
  2. import cn.dev33.satoken.annotation.SaCheckPermission;
  3. import com.ruoyi.common.annotation.Log;
  4. import com.ruoyi.common.constant.UserConstants;
  5. import com.ruoyi.common.core.controller.BaseController;
  6. import com.ruoyi.common.core.domain.AjaxResult;
  7. import com.ruoyi.common.core.domain.entity.SysRole;
  8. import com.ruoyi.common.core.domain.entity.SysUser;
  9. import com.ruoyi.common.core.page.TableDataInfo;
  10. import com.ruoyi.common.enums.BusinessType;
  11. import com.ruoyi.common.utils.poi.ExcelUtil;
  12. import com.ruoyi.system.domain.SysUserRole;
  13. import com.ruoyi.system.service.ISysRoleService;
  14. import com.ruoyi.system.service.ISysUserService;
  15. import io.swagger.annotations.Api;
  16. import io.swagger.annotations.ApiOperation;
  17. import lombok.RequiredArgsConstructor;
  18. import org.springframework.beans.factory.annotation.Autowired;
  19. import org.springframework.validation.annotation.Validated;
  20. import org.springframework.web.bind.annotation.*;
  21. import javax.servlet.http.HttpServletResponse;
  22. import java.util.List;
  23. /**
  24. * 角色信息
  25. *
  26. * @author Lion Li
  27. */
  28. @Validated
  29. @Api(value = "角色信息控制器", tags = {"角色信息管理"})
  30. @RequiredArgsConstructor(onConstructor_ = @Autowired)
  31. @RestController
  32. @RequestMapping("/system/role")
  33. public class SysRoleController extends BaseController {
  34. private final ISysRoleService roleService;
  35. private final ISysUserService userService;
  36. @ApiOperation("查询角色信息列表")
  37. @SaCheckPermission("system:role:list")
  38. @GetMapping("/list")
  39. public TableDataInfo<SysRole> list(SysRole role) {
  40. return roleService.selectPageRoleList(role);
  41. }
  42. @ApiOperation("导出角色信息列表")
  43. @Log(title = "角色管理", businessType = BusinessType.EXPORT)
  44. @SaCheckPermission("system:role:export")
  45. @GetMapping("/export")
  46. public void export(SysRole role, HttpServletResponse response) {
  47. List<SysRole> list = roleService.selectRoleList(role);
  48. ExcelUtil.exportExcel(list, "角色数据", SysRole.class, response);
  49. }
  50. /**
  51. * 根据角色编号获取详细信息
  52. */
  53. @ApiOperation("根据角色编号获取详细信息")
  54. @SaCheckPermission("system:role:query")
  55. @GetMapping(value = "/{roleId}")
  56. public AjaxResult<SysRole> getInfo(@PathVariable Long roleId) {
  57. roleService.checkRoleDataScope(roleId);
  58. return AjaxResult.success(roleService.selectRoleById(roleId));
  59. }
  60. /**
  61. * 新增角色
  62. */
  63. @ApiOperation("新增角色")
  64. @SaCheckPermission("system:role:add")
  65. @Log(title = "角色管理", businessType = BusinessType.INSERT)
  66. @PostMapping
  67. public AjaxResult<Void> add(@Validated @RequestBody SysRole role) {
  68. if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) {
  69. return AjaxResult.error("新增角色'" + role.getRoleName() + "'失败,角色名称已存在");
  70. } else if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleKeyUnique(role))) {
  71. return AjaxResult.error("新增角色'" + role.getRoleName() + "'失败,角色权限已存在");
  72. }
  73. return toAjax(roleService.insertRole(role));
  74. }
  75. /**
  76. * 修改保存角色
  77. */
  78. @ApiOperation("修改保存角色")
  79. @SaCheckPermission("system:role:edit")
  80. @Log(title = "角色管理", businessType = BusinessType.UPDATE)
  81. @PutMapping
  82. public AjaxResult<Void> edit(@Validated @RequestBody SysRole role) {
  83. roleService.checkRoleAllowed(role);
  84. if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) {
  85. return AjaxResult.error("修改角色'" + role.getRoleName() + "'失败,角色名称已存在");
  86. } else if (UserConstants.NOT_UNIQUE.equals(roleService.checkRoleKeyUnique(role))) {
  87. return AjaxResult.error("修改角色'" + role.getRoleName() + "'失败,角色权限已存在");
  88. }
  89. if (roleService.updateRole(role) > 0) {
  90. return AjaxResult.success();
  91. }
  92. return AjaxResult.error("修改角色'" + role.getRoleName() + "'失败,请联系管理员");
  93. }
  94. /**
  95. * 修改保存数据权限
  96. */
  97. @ApiOperation("修改保存数据权限")
  98. @SaCheckPermission("system:role:edit")
  99. @Log(title = "角色管理", businessType = BusinessType.UPDATE)
  100. @PutMapping("/dataScope")
  101. public AjaxResult<Void> dataScope(@RequestBody SysRole role) {
  102. roleService.checkRoleAllowed(role);
  103. return toAjax(roleService.authDataScope(role));
  104. }
  105. /**
  106. * 状态修改
  107. */
  108. @ApiOperation("状态修改")
  109. @SaCheckPermission("system:role:edit")
  110. @Log(title = "角色管理", businessType = BusinessType.UPDATE)
  111. @PutMapping("/changeStatus")
  112. public AjaxResult<Void> changeStatus(@RequestBody SysRole role) {
  113. roleService.checkRoleAllowed(role);
  114. return toAjax(roleService.updateRoleStatus(role));
  115. }
  116. /**
  117. * 删除角色
  118. */
  119. @ApiOperation("删除角色")
  120. @SaCheckPermission("system:role:remove")
  121. @Log(title = "角色管理", businessType = BusinessType.DELETE)
  122. @DeleteMapping("/{roleIds}")
  123. public AjaxResult<Void> remove(@PathVariable Long[] roleIds) {
  124. return toAjax(roleService.deleteRoleByIds(roleIds));
  125. }
  126. /**
  127. * 获取角色选择框列表
  128. */
  129. @ApiOperation("获取角色选择框列表")
  130. @SaCheckPermission("system:role:query")
  131. @GetMapping("/optionselect")
  132. public AjaxResult<List<SysRole>> optionselect() {
  133. return AjaxResult.success(roleService.selectRoleAll());
  134. }
  135. /**
  136. * 查询已分配用户角色列表
  137. */
  138. @ApiOperation("查询已分配用户角色列表")
  139. @SaCheckPermission("system:role:list")
  140. @GetMapping("/authUser/allocatedList")
  141. public TableDataInfo<SysUser> allocatedList(SysUser user) {
  142. return userService.selectAllocatedList(user);
  143. }
  144. /**
  145. * 查询未分配用户角色列表
  146. */
  147. @ApiOperation("查询未分配用户角色列表")
  148. @SaCheckPermission("system:role:list")
  149. @GetMapping("/authUser/unallocatedList")
  150. public TableDataInfo<SysUser> unallocatedList(SysUser user) {
  151. return userService.selectUnallocatedList(user);
  152. }
  153. /**
  154. * 取消授权用户
  155. */
  156. @ApiOperation("取消授权用户")
  157. @SaCheckPermission("system:role:edit")
  158. @Log(title = "角色管理", businessType = BusinessType.GRANT)
  159. @PutMapping("/authUser/cancel")
  160. public AjaxResult<Void> cancelAuthUser(@RequestBody SysUserRole userRole) {
  161. return toAjax(roleService.deleteAuthUser(userRole));
  162. }
  163. /**
  164. * 批量取消授权用户
  165. */
  166. @ApiOperation("批量取消授权用户")
  167. @SaCheckPermission("system:role:edit")
  168. @Log(title = "角色管理", businessType = BusinessType.GRANT)
  169. @PutMapping("/authUser/cancelAll")
  170. public AjaxResult<Void> cancelAuthUserAll(Long roleId, Long[] userIds) {
  171. return toAjax(roleService.deleteAuthUsers(roleId, userIds));
  172. }
  173. /**
  174. * 批量选择用户授权
  175. */
  176. @ApiOperation("批量选择用户授权")
  177. @SaCheckPermission("system:role:edit")
  178. @Log(title = "角色管理", businessType = BusinessType.GRANT)
  179. @PutMapping("/authUser/selectAll")
  180. public AjaxResult<Void> selectAuthUserAll(Long roleId, Long[] userIds) {
  181. return toAjax(roleService.insertAuthUsers(roleId, userIds));
  182. }
  183. }