UsersMenuController.java 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. package com.template.controller;
  2. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  3. import com.baomidou.mybatisplus.core.metadata.IPage;
  4. import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
  5. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  6. import com.template.api.UsersMenuAPI;
  7. import com.template.model.dto.SaveParentUserDto;
  8. import com.template.model.dto.SaveSecondaryUserDto;
  9. import com.template.model.pojo.PermissionSetting;
  10. import com.template.model.pojo.Users;
  11. import com.template.model.pojo.UsersMenu;
  12. import com.template.model.result.CommonResult;
  13. import com.template.model.vo.AdminMenuTreeVo;
  14. import com.template.services.PermissionSettingService;
  15. import com.template.services.UsersMenuService;
  16. import com.template.services.UsersService;
  17. import org.springframework.beans.factory.annotation.Autowired;
  18. import org.springframework.web.bind.annotation.RestController;
  19. import java.util.ArrayList;
  20. import java.util.List;
  21. import java.util.stream.Collectors;
  22. /**
  23. * <p>
  24. * 前端控制器
  25. * </p>
  26. *
  27. * @author ceshi
  28. * @since 2023-12-13
  29. */
  30. @RestController
  31. public class UsersMenuController implements UsersMenuAPI {
  32. @Autowired
  33. UsersMenuService usersMenuService;
  34. @Autowired
  35. PermissionSettingService permissionSettingService;
  36. @Autowired
  37. UsersService usersService;
  38. public static void main(String[] args) {
  39. String s = "1,2";
  40. boolean contains = s.contains("3");
  41. System.out.println("contains = " + contains);
  42. }
  43. @Override
  44. public CommonResult saveUserParent(SaveParentUserDto saveParentUserDto) {
  45. if (ObjectUtils.isEmpty(saveParentUserDto)) {
  46. return CommonResult.fail();
  47. }
  48. int adminId = saveParentUserDto.getAdminMenuId();
  49. PermissionSetting permissionSetting = permissionSettingService.getById(adminId);
  50. if (ObjectUtils.isEmpty(permissionSetting)) {
  51. return CommonResult.fail("非法进入");
  52. }
  53. // 判断该用户是否拥有权限
  54. String roleManagement = permissionSetting.getRoleManagement();
  55. if (!"0".equals(roleManagement) && !roleManagement.contains("1")) {
  56. return CommonResult.fail("此账号暂无该权限");
  57. }
  58. String name = saveParentUserDto.getName();
  59. LambdaQueryWrapper<UsersMenu> wrapperUm = new LambdaQueryWrapper<>();
  60. wrapperUm.eq(UsersMenu::getName, name);
  61. UsersMenu one = usersMenuService.getOne(wrapperUm);
  62. if (ObjectUtils.isNotEmpty(one)) {
  63. return CommonResult.fail("已有该角色");
  64. }
  65. UsersMenu usersMenu = new UsersMenu();
  66. usersMenu.setParentId(0);
  67. usersMenu.setName(name);
  68. usersMenuService.save(usersMenu);
  69. return CommonResult.ok();
  70. }
  71. @Override
  72. public CommonResult saveUserSecondary(SaveSecondaryUserDto saveSecondaryUserDto) {
  73. if (ObjectUtils.isEmpty(saveSecondaryUserDto)) {
  74. return CommonResult.fail();
  75. }
  76. int adminId = saveSecondaryUserDto.getAdminMenuId();
  77. PermissionSetting permissionSetting = permissionSettingService.getById(adminId);
  78. if (ObjectUtils.isEmpty(permissionSetting)) {
  79. return CommonResult.fail("非法进入");
  80. }
  81. // 判断该用户是否拥有权限
  82. String roleManagement = permissionSetting.getRoleManagement();
  83. if (!"0".equals(roleManagement) && !roleManagement.contains("1")) {
  84. return CommonResult.fail("此账号暂无该权限");
  85. }
  86. String name = saveSecondaryUserDto.getName();
  87. LambdaQueryWrapper<UsersMenu> wrapperUm = new LambdaQueryWrapper<>();
  88. wrapperUm.eq(UsersMenu::getName, name);
  89. UsersMenu one = usersMenuService.getOne(wrapperUm);
  90. if (ObjectUtils.isNotEmpty(one)) {
  91. return CommonResult.fail("已有该角色");
  92. }
  93. UsersMenu usersMenu = new UsersMenu();
  94. usersMenu.setParentId(saveSecondaryUserDto.getParentId());
  95. usersMenu.setName(name);
  96. usersMenuService.save(usersMenu);
  97. return CommonResult.ok();
  98. }
  99. @Override
  100. public CommonResult userListPage(int adminMenuId,int page, int size, String keyWord, String startTime, String endTime) {
  101. PermissionSetting permissionSetting = permissionSettingService.getById(adminMenuId);
  102. if (ObjectUtils.isEmpty(permissionSetting)) {
  103. return CommonResult.fail("非法进入");
  104. }
  105. // 判断该用户是否拥有权限
  106. String roleManagement = permissionSetting.getRoleManagement();
  107. if (!"0".equals(roleManagement) && !roleManagement.contains("4")) {
  108. return CommonResult.fail("此账号暂无该权限");
  109. }
  110. if (ObjectUtils.isEmpty(page) && page <= 0) {
  111. page = 1;
  112. }
  113. if (ObjectUtils.isEmpty(size) && size <= 0) {
  114. size = 10;
  115. }
  116. LambdaQueryWrapper<UsersMenu> wrapperUM = new LambdaQueryWrapper<>();
  117. wrapperUM.like(ObjectUtils.isNotEmpty(keyWord), UsersMenu::getName, keyWord)
  118. .between(ObjectUtils.isNotEmpty(startTime) && ObjectUtils.isNotEmpty(endTime), UsersMenu::getCreateTime, startTime, endTime);
  119. IPage<UsersMenu> page1 = usersMenuService.page(new Page<>(page, size), wrapperUM);
  120. return CommonResult.ok(page1);
  121. }
  122. @Override
  123. public CommonResult deleteUsersMenu(int adminMenuId, int userMenuId) {
  124. PermissionSetting permissionSetting = permissionSettingService.getById(adminMenuId);
  125. if (ObjectUtils.isEmpty(permissionSetting)) {
  126. return CommonResult.fail("非法进入");
  127. }
  128. // 判断该用户是否拥有权限
  129. String roleManagement = permissionSetting.getRoleManagement();
  130. if (!"0".equals(roleManagement) && !roleManagement.contains("3")) {
  131. return CommonResult.fail("此账号暂无该权限");
  132. }
  133. // 判断是否有子用户角色
  134. List<UsersMenu> usersMenuList=usersMenuService.listUserMenuId(userMenuId);
  135. List<Users> users=usersService.listUserMenuId(userMenuId);
  136. if (users.size()>0) {
  137. return CommonResult.fail("该角色下还有用户");
  138. }
  139. if (ObjectUtils.isNotEmpty(usersMenuList)&&usersMenuList.size()>0) {
  140. return CommonResult.fail("该角色下还有其他角色未删除");
  141. }
  142. boolean b = usersMenuService.removeById(userMenuId);
  143. if (!b) {
  144. return CommonResult.fail("删除失败");
  145. }
  146. return CommonResult.ok();
  147. }
  148. /**
  149. * 根据父类ID获取树形菜单数据
  150. *
  151. * @param parentID 父级ID
  152. * @param lists 数据集合
  153. * @return
  154. */
  155. private List<AdminMenuTreeVo> QueryAreaTreeRecords(Integer parentID, List<UsersMenu> lists) {
  156. List<AdminMenuTreeVo> newTrees = new ArrayList<>();
  157. List<UsersMenu> datas = lists.stream().filter(e -> e.getParentId().equals(parentID)).collect(Collectors.toList());
  158. for (UsersMenu data : datas) {
  159. AdminMenuTreeVo item = AdminMenuTreeVo.builder()
  160. .id(data.getId())
  161. .parentId(data.getParentId())
  162. .name(data.getName())
  163. .build();
  164. List<AdminMenuTreeVo> news = QueryAreaTreeRecords(item.getId(), lists);
  165. if (news == null || news.size() == 0) {
  166. newTrees.add(item);
  167. continue;
  168. } else {
  169. item.setChildren(news);
  170. newTrees.add(item);
  171. }
  172. }
  173. return newTrees;
  174. }
  175. }