SysMenuController.java 5.3 KB

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