SysMenuController.java 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. package com.ruoyi.web.controller.system;
  2. import cn.hutool.core.util.StrUtil;
  3. import com.ruoyi.common.annotation.Log;
  4. import com.ruoyi.common.constant.Constants;
  5. import com.ruoyi.common.constant.UserConstants;
  6. import com.ruoyi.common.core.controller.BaseController;
  7. import com.ruoyi.common.core.domain.AjaxResult;
  8. import com.ruoyi.common.core.domain.entity.SysMenu;
  9. import com.ruoyi.common.core.domain.model.LoginUser;
  10. import com.ruoyi.common.enums.BusinessType;
  11. import com.ruoyi.common.utils.SecurityUtils;
  12. import com.ruoyi.common.utils.ServletUtils;
  13. import com.ruoyi.framework.web.service.TokenService;
  14. import com.ruoyi.system.service.ISysMenuService;
  15. import org.springframework.beans.factory.annotation.Autowired;
  16. import org.springframework.security.access.prepost.PreAuthorize;
  17. import org.springframework.validation.annotation.Validated;
  18. import org.springframework.web.bind.annotation.*;
  19. import java.util.HashMap;
  20. import java.util.List;
  21. import java.util.Map;
  22. /**
  23. * 菜单信息
  24. *
  25. * @author ruoyi
  26. */
  27. @RestController
  28. @RequestMapping("/system/menu")
  29. public class SysMenuController extends BaseController
  30. {
  31. @Autowired
  32. private ISysMenuService menuService;
  33. @Autowired
  34. private TokenService tokenService;
  35. /**
  36. * 获取菜单列表
  37. */
  38. @PreAuthorize("@ss.hasPermi('system:menu:list')")
  39. @GetMapping("/list")
  40. public AjaxResult list(SysMenu menu)
  41. {
  42. LoginUser loginUser = tokenService.getLoginUser(ServletUtils.getRequest());
  43. Long userId = loginUser.getUser().getUserId();
  44. List<SysMenu> menus = menuService.selectMenuList(menu, userId);
  45. return AjaxResult.success(menus);
  46. }
  47. /**
  48. * 根据菜单编号获取详细信息
  49. */
  50. @PreAuthorize("@ss.hasPermi('system:menu:query')")
  51. @GetMapping(value = "/{menuId}")
  52. public AjaxResult getInfo(@PathVariable Long menuId)
  53. {
  54. return AjaxResult.success(menuService.selectMenuById(menuId));
  55. }
  56. /**
  57. * 获取菜单下拉树列表
  58. */
  59. @GetMapping("/treeselect")
  60. public AjaxResult treeselect(SysMenu menu)
  61. {
  62. LoginUser loginUser = tokenService.getLoginUser(ServletUtils.getRequest());
  63. Long userId = loginUser.getUser().getUserId();
  64. List<SysMenu> menus = menuService.selectMenuList(menu, userId);
  65. return AjaxResult.success(menuService.buildMenuTreeSelect(menus));
  66. }
  67. /**
  68. * 加载对应角色菜单列表树
  69. */
  70. @GetMapping(value = "/roleMenuTreeselect/{roleId}")
  71. public AjaxResult roleMenuTreeselect(@PathVariable("roleId") Long roleId)
  72. {
  73. LoginUser loginUser = tokenService.getLoginUser(ServletUtils.getRequest());
  74. List<SysMenu> menus = menuService.selectMenuList(loginUser.getUser().getUserId());
  75. Map<String,Object> ajax = new HashMap<>();
  76. ajax.put("checkedKeys", menuService.selectMenuListByRoleId(roleId));
  77. ajax.put("menus", menuService.buildMenuTreeSelect(menus));
  78. return AjaxResult.success(ajax);
  79. }
  80. /**
  81. * 新增菜单
  82. */
  83. @PreAuthorize("@ss.hasPermi('system:menu:add')")
  84. @Log(title = "菜单管理", businessType = BusinessType.INSERT)
  85. @PostMapping
  86. public AjaxResult add(@Validated @RequestBody SysMenu menu)
  87. {
  88. if (UserConstants.NOT_UNIQUE.equals(menuService.checkMenuNameUnique(menu)))
  89. {
  90. return AjaxResult.error("新增菜单'" + menu.getMenuName() + "'失败,菜单名称已存在");
  91. }
  92. else if (UserConstants.YES_FRAME.equals(menu.getIsFrame())
  93. && !StrUtil.startWithAny(menu.getPath(), Constants.HTTP, Constants.HTTPS))
  94. {
  95. return AjaxResult.error("新增菜单'" + menu.getMenuName() + "'失败,地址必须以http(s)://开头");
  96. }
  97. menu.setCreateBy(SecurityUtils.getUsername());
  98. return toAjax(menuService.insertMenu(menu));
  99. }
  100. /**
  101. * 修改菜单
  102. */
  103. @PreAuthorize("@ss.hasPermi('system:menu:edit')")
  104. @Log(title = "菜单管理", businessType = BusinessType.UPDATE)
  105. @PutMapping
  106. public AjaxResult edit(@Validated @RequestBody SysMenu menu)
  107. {
  108. if (UserConstants.NOT_UNIQUE.equals(menuService.checkMenuNameUnique(menu)))
  109. {
  110. return AjaxResult.error("修改菜单'" + menu.getMenuName() + "'失败,菜单名称已存在");
  111. }
  112. else if (UserConstants.YES_FRAME.equals(menu.getIsFrame())
  113. && !StrUtil.startWithAny(menu.getPath(), Constants.HTTP, Constants.HTTPS))
  114. {
  115. return AjaxResult.error("修改菜单'" + menu.getMenuName() + "'失败,地址必须以http(s)://开头");
  116. }
  117. else if (menu.getMenuId().equals(menu.getParentId()))
  118. {
  119. return AjaxResult.error("修改菜单'" + menu.getMenuName() + "'失败,上级菜单不能选择自己");
  120. }
  121. menu.setUpdateBy(SecurityUtils.getUsername());
  122. return toAjax(menuService.updateMenu(menu));
  123. }
  124. /**
  125. * 删除菜单
  126. */
  127. @PreAuthorize("@ss.hasPermi('system:menu:remove')")
  128. @Log(title = "菜单管理", businessType = BusinessType.DELETE)
  129. @DeleteMapping("/{menuId}")
  130. public AjaxResult remove(@PathVariable("menuId") Long menuId)
  131. {
  132. if (menuService.hasChildByMenuId(menuId))
  133. {
  134. return AjaxResult.error("存在子菜单,不允许删除");
  135. }
  136. if (menuService.checkMenuExistRole(menuId))
  137. {
  138. return AjaxResult.error("菜单已分配,不允许删除");
  139. }
  140. return toAjax(menuService.deleteMenuById(menuId));
  141. }
  142. }