SysRoleController.java 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. package com.iden.bms.controller;
  2. import com.baomidou.mybatisplus.core.metadata.IPage;
  3. import com.iden.bms.service.SysRoleService;
  4. import com.iden.common.annotation.Permission;
  5. import com.iden.common.exception.BDException;
  6. import com.iden.common.logaspect.LogAnnotation;
  7. import com.iden.common.logaspect.OperateType;
  8. import com.iden.common.util.PageResult;
  9. import com.iden.common.util.Result;
  10. import com.iden.common.util.WebPageUtils;
  11. import com.iden.common.vo.PageReqVO;
  12. import com.iden.common.vo.SysMenuVO;
  13. import com.iden.common.vo.SysRoleVO;
  14. import com.iden.common.vo.UserLoginedConvertVO;
  15. import io.swagger.annotations.Api;
  16. import io.swagger.annotations.ApiImplicitParam;
  17. import io.swagger.annotations.ApiImplicitParams;
  18. import io.swagger.annotations.ApiOperation;
  19. import lombok.extern.slf4j.Slf4j;
  20. import org.springframework.beans.factory.annotation.Autowired;
  21. import org.springframework.web.bind.annotation.*;
  22. import javax.servlet.http.HttpServletRequest;
  23. import java.util.List;
  24. /**
  25. * @Author: lilt
  26. * @Date: 2021/5/26
  27. * @Desc:
  28. */
  29. @RestController
  30. @Api(value = "SysRoleController", tags = { "角色管理" })
  31. @Slf4j
  32. @RequestMapping("/bms/sysRole")
  33. @Permission
  34. public class SysRoleController {
  35. @Autowired
  36. private SysRoleService sysRoleService;
  37. @GetMapping("/listSysRole")
  38. @ApiOperation(value = "角色列表分页 ")
  39. public PageResult<List<SysRoleVO>> listSysRole(HttpServletRequest request, @RequestHeader(value = "token") String token,
  40. PageReqVO pageReqVo){
  41. try {
  42. UserLoginedConvertVO loginUser = WebPageUtils.getCurrentLoginedUser(request);
  43. IPage<SysRoleVO> pageResponse = this.sysRoleService.listSysRole(loginUser ,pageReqVo);
  44. return PageResult.success(pageResponse.getRecords(),pageResponse.getCurrent(),pageResponse.getSize(),pageResponse.getTotal());
  45. }catch (BDException e) {
  46. log.error("角色列表查询-分页列表出现异常",e);
  47. return PageResult.error(e.getMessage());
  48. } catch (Exception e) {
  49. log.error("角色管理: 角色列表查询出现异常",e);
  50. return PageResult.error( "获取列表失败");
  51. }
  52. }
  53. @PostMapping("/addSysRole")
  54. @ApiOperation(value = "新增角色")
  55. @LogAnnotation(
  56. type = OperateType.ADD,
  57. moduleName = "新增角色",
  58. description = "新增角色"
  59. )
  60. public Result<Object> addSysRole(HttpServletRequest request,@RequestHeader("token") String token,
  61. @RequestBody SysRoleVO vo){
  62. try {
  63. UserLoginedConvertVO loginUser = WebPageUtils.getCurrentLoginedUser(request);
  64. int flag = this.sysRoleService.createSysRole(vo,loginUser);
  65. if (flag == 1) {
  66. return Result.error("名称已存在!");
  67. } if (flag == 2) {
  68. return Result.error("编码已存在!");
  69. } else if (flag == 0) {
  70. return Result.success("新增成功!");
  71. } else {
  72. return Result.error("新增失败!");
  73. }
  74. }catch (BDException e) {
  75. log.error("新增角色-出现异常",e);
  76. return Result.error(e.getMessage());
  77. } catch (Exception e) {
  78. log.error("角色管理: 新增角色出现异常",e);
  79. return Result.error("新增失败!");
  80. }
  81. }
  82. @PostMapping("/updateSysRole")
  83. @ApiOperation(value = "修改角色")
  84. @LogAnnotation(
  85. type = OperateType.MODIFY,
  86. moduleName = "修改角色",
  87. description = "修改角色"
  88. )
  89. public Result<Object> updateSysRole(@RequestHeader("token") String token,
  90. @RequestBody SysRoleVO vo){
  91. try {
  92. this.sysRoleService.updateSysRole(vo);
  93. return Result.success("修改成功!");
  94. }catch (BDException e) {
  95. log.error("修改角色-出现异常",e);
  96. return Result.error(e.getMessage());
  97. } catch (Exception e) {
  98. log.error("角色管理: 修改角色出现异常",e);
  99. return Result.error("修改失败!");
  100. }
  101. }
  102. @PostMapping("/invalidSysRole")
  103. @ApiOperation(value = "启用停用(只设置id和validStatus(0启用,1停用))")
  104. @LogAnnotation(
  105. type = OperateType.MODIFY,
  106. moduleName = "启用停用",
  107. description = "启用停用"
  108. )
  109. public Result<Object> invalidSysRole(@RequestHeader("token") String token,
  110. @RequestBody SysRoleVO vo){
  111. try {
  112. sysRoleService.invalidSysRole(vo);
  113. return Result.success("操作成功!");
  114. }catch (BDException e) {
  115. log.error("启用停用角色出现异常",e);
  116. return Result.error(e.getMessage());
  117. } catch (Exception e) {
  118. log.error("角色管理: 启用停用角色出现异常",e);
  119. return Result.error("启用停用角色失败!");
  120. }
  121. }
  122. @GetMapping("/getSysRoleInfo/{id}")
  123. @ApiOperation(value = "角色详情")
  124. public Result<SysRoleVO> getSysRoleInfo(HttpServletRequest request, @RequestHeader("token") String token, @PathVariable("id") Long id){
  125. SysRoleVO orderInfo = this.sysRoleService.getSysRoleById(id);
  126. return Result.success("查询成功!",orderInfo);
  127. }
  128. @PostMapping("/deleteSysRole/{id}")
  129. @ApiOperation(value = "删除角色")
  130. @LogAnnotation(
  131. type = OperateType.REMOVE,
  132. moduleName = "删除角色",
  133. description = "删除角色"
  134. )
  135. public Result<Object> deleteSysRole(HttpServletRequest request,@RequestHeader("token") String token,
  136. @PathVariable("id") Long id){
  137. try {
  138. if( this.sysRoleService.deleteById(id)){
  139. return Result.success("删除成功!");
  140. } else {
  141. return Result.error("角色被引用,删除失败!");
  142. }
  143. } catch (Exception e) {
  144. log.error("角色管理: 删除出现异常",e);
  145. return Result.error("删除失败!");
  146. }
  147. }
  148. @GetMapping("/listNoHasLeafMenu")
  149. @ApiOperation(value = "获取没有拥有的叶子菜单")
  150. @ApiImplicitParams(value = {
  151. @ApiImplicitParam(paramType = "query", name = "id", value = "角色ID"),
  152. })
  153. public Result<List<SysMenuVO>> listNoHasLeafMenu(HttpServletRequest request, @RequestHeader(value = "token") String token,
  154. @RequestParam(value = "id", required = false) Long id) {
  155. try {
  156. UserLoginedConvertVO loginUser = WebPageUtils.getCurrentLoginedUser(request);
  157. List<SysMenuVO> datas = this.sysRoleService.listNoHasLeafMenu(loginUser,id);
  158. return Result.success(datas);
  159. }catch (Exception e) {
  160. log.error("角色管理: 获取没有拥有的叶子菜单出现异常",e);
  161. return Result.error( "获取列表失败");
  162. }
  163. }
  164. @GetMapping("/listHasLeafMenu")
  165. @ApiOperation(value = "获取拥有的叶子菜单")
  166. @ApiImplicitParams(value = {
  167. @ApiImplicitParam(paramType = "query", name = "id", value = "角色ID"),
  168. })
  169. public Result<List<SysMenuVO>> listHasLeafMenu(HttpServletRequest request, @RequestHeader(value = "token") String token,
  170. @RequestParam(value = "id", required = false) Long id) {
  171. try {
  172. UserLoginedConvertVO loginUser = WebPageUtils.getCurrentLoginedUser(request);
  173. List<SysMenuVO> datas = this.sysRoleService.listHasLeafMenu(loginUser,id);
  174. return Result.success(datas);
  175. }catch (Exception e) {
  176. log.error("角色管理: 获取拥有的叶子菜单出现异常",e);
  177. return Result.error( "获取列表失败");
  178. }
  179. }
  180. @PostMapping("/saveSysRoleMenu")
  181. @ApiOperation(value = "保存角色拥有的菜单,SysRoleVO设置菜单id和hasSysMenuVOList")
  182. @LogAnnotation(
  183. type = OperateType.MODIFY,
  184. moduleName = "保存角色拥有的菜单",
  185. description = "保存角色拥有的菜单"
  186. )
  187. public Result<Object> saveSysRoleMenu(HttpServletRequest request,
  188. @RequestHeader("token") String token,
  189. @RequestBody SysRoleVO vo){
  190. try {
  191. UserLoginedConvertVO loginUser = WebPageUtils.getCurrentLoginedUser(request);
  192. this.sysRoleService.saveSysRoleMenu(loginUser,vo);
  193. return Result.success("保存成功!");
  194. }catch (BDException e) {
  195. log.error("保存角色拥有的菜单-出现异常",e);
  196. return Result.error(e.getMessage());
  197. } catch (Exception e) {
  198. log.error("角色管理: 保存角色拥有的菜单出现异常",e);
  199. return Result.error("保存失败!");
  200. }
  201. }
  202. }