package com.ruoyi.web.system; import java.util.List; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.ui.ModelMap; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; import com.ruoyi.common.annotation.Log; import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.Ztree; import com.ruoyi.common.core.domain.entity.SysRole; import com.ruoyi.common.core.domain.entity.SysUser; import com.ruoyi.common.core.page.TableDataInfo; import com.ruoyi.common.enums.BusinessType; import com.ruoyi.common.utils.poi.ExcelUtil; import com.ruoyi.framework.shiro.util.AuthorizationUtils; import com.ruoyi.web.domain.system.SysUserRole; import com.ruoyi.web.server.system.ISysDeptService; import com.ruoyi.web.server.system.ISysRoleService; import com.ruoyi.web.server.system.ISysUserService; /** * 角色信息 * * @author ruoyi */ @Controller @RequestMapping("/system/role") public class SysRoleController extends BaseController { private String prefix = "system/role"; @Autowired private ISysRoleService roleService; @Autowired private ISysUserService userService; @Autowired private ISysDeptService deptService; @RequiresPermissions("system:role:view") @GetMapping() public String role() { return prefix + "/role"; } @RequiresPermissions("system:role:list") @PostMapping("/list") @ResponseBody public TableDataInfo list(SysRole role) { startPage(); List list = roleService.selectRoleList(role); return getDataTable(list); } @Log(title = "角色管理", businessType = BusinessType.EXPORT) @RequiresPermissions("system:role:export") @PostMapping("/export") @ResponseBody public AjaxResult export(SysRole role) { List list = roleService.selectRoleList(role); ExcelUtil util = new ExcelUtil(SysRole.class); return util.exportExcel(list, "角色数据"); } /** * 新增角色 */ @GetMapping("/add") public String add() { return prefix + "/add"; } /** * 新增保存角色 */ @RequiresPermissions("system:role:add") @Log(title = "角色管理", businessType = BusinessType.INSERT) @PostMapping("/add") @ResponseBody public AjaxResult addSave(@Validated SysRole role) { if (!roleService.checkRoleNameUnique(role)) { return error("新增角色'" + role.getRoleName() + "'失败,角色名称已存在"); } else if (!roleService.checkRoleKeyUnique(role)) { return error("新增角色'" + role.getRoleName() + "'失败,角色权限已存在"); } role.setCreateBy(getLoginName()); AuthorizationUtils.clearAllCachedAuthorizationInfo(); return toAjax(roleService.insertRole(role)); } /** * 修改角色 */ @RequiresPermissions("system:role:edit") @GetMapping("/edit/{roleId}") public String edit(@PathVariable("roleId") Long roleId, ModelMap mmap) { roleService.checkRoleDataScope(roleId); mmap.put("role", roleService.selectRoleById(roleId)); return prefix + "/edit"; } /** * 修改保存角色 */ @RequiresPermissions("system:role:edit") @Log(title = "角色管理", businessType = BusinessType.UPDATE) @PostMapping("/edit") @ResponseBody public AjaxResult editSave(@Validated SysRole role) { roleService.checkRoleAllowed(role); roleService.checkRoleDataScope(role.getRoleId()); if (!roleService.checkRoleNameUnique(role)) { return error("修改角色'" + role.getRoleName() + "'失败,角色名称已存在"); } else if (!roleService.checkRoleKeyUnique(role)) { return error("修改角色'" + role.getRoleName() + "'失败,角色权限已存在"); } role.setUpdateBy(getLoginName()); AuthorizationUtils.clearAllCachedAuthorizationInfo(); return toAjax(roleService.updateRole(role)); } /** * 角色分配数据权限 */ @GetMapping("/authDataScope/{roleId}") public String authDataScope(@PathVariable("roleId") Long roleId, ModelMap mmap) { mmap.put("role", roleService.selectRoleById(roleId)); return prefix + "/dataScope"; } /** * 保存角色分配数据权限 */ @RequiresPermissions("system:role:edit") @Log(title = "角色管理", businessType = BusinessType.UPDATE) @PostMapping("/authDataScope") @ResponseBody public AjaxResult authDataScopeSave(SysRole role) { roleService.checkRoleAllowed(role); roleService.checkRoleDataScope(role.getRoleId()); role.setUpdateBy(getLoginName()); if (roleService.authDataScope(role) > 0) { setSysUser(userService.selectUserById(getUserId())); return success(); } return error(); } @RequiresPermissions("system:role:remove") @Log(title = "角色管理", businessType = BusinessType.DELETE) @PostMapping("/remove") @ResponseBody public AjaxResult remove(String ids) { return toAjax(roleService.deleteRoleByIds(ids)); } /** * 校验角色名称 */ @PostMapping("/checkRoleNameUnique") @ResponseBody public boolean checkRoleNameUnique(SysRole role) { return roleService.checkRoleNameUnique(role); } /** * 校验角色权限 */ @PostMapping("/checkRoleKeyUnique") @ResponseBody public boolean checkRoleKeyUnique(SysRole role) { return roleService.checkRoleKeyUnique(role); } /** * 选择菜单树 */ @GetMapping("/selectMenuTree") public String selectMenuTree() { return prefix + "/tree"; } /** * 角色状态修改 */ @Log(title = "角色管理", businessType = BusinessType.UPDATE) @RequiresPermissions("system:role:edit") @PostMapping("/changeStatus") @ResponseBody public AjaxResult changeStatus(SysRole role) { roleService.checkRoleAllowed(role); roleService.checkRoleDataScope(role.getRoleId()); return toAjax(roleService.changeStatus(role)); } /** * 分配用户 */ @RequiresPermissions("system:role:edit") @GetMapping("/authUser/{roleId}") public String authUser(@PathVariable("roleId") Long roleId, ModelMap mmap) { mmap.put("role", roleService.selectRoleById(roleId)); return prefix + "/authUser"; } /** * 查询已分配用户角色列表 */ @RequiresPermissions("system:role:list") @PostMapping("/authUser/allocatedList") @ResponseBody public TableDataInfo allocatedList(SysUser user) { startPage(); List list = userService.selectAllocatedList(user); return getDataTable(list); } /** * 取消授权 */ @RequiresPermissions("system:role:edit") @Log(title = "角色管理", businessType = BusinessType.GRANT) @PostMapping("/authUser/cancel") @ResponseBody public AjaxResult cancelAuthUser(SysUserRole userRole) { return toAjax(roleService.deleteAuthUser(userRole)); } /** * 批量取消授权 */ @RequiresPermissions("system:role:edit") @Log(title = "角色管理", businessType = BusinessType.GRANT) @PostMapping("/authUser/cancelAll") @ResponseBody public AjaxResult cancelAuthUserAll(Long roleId, String userIds) { return toAjax(roleService.deleteAuthUsers(roleId, userIds)); } /** * 选择用户 */ @GetMapping("/authUser/selectUser/{roleId}") public String selectUser(@PathVariable("roleId") Long roleId, ModelMap mmap) { mmap.put("role", roleService.selectRoleById(roleId)); return prefix + "/selectUser"; } /** * 查询未分配用户角色列表 */ @RequiresPermissions("system:role:list") @PostMapping("/authUser/unallocatedList") @ResponseBody public TableDataInfo unallocatedList(SysUser user) { startPage(); List list = userService.selectUnallocatedList(user); return getDataTable(list); } /** * 批量选择用户授权 */ @RequiresPermissions("system:role:edit") @Log(title = "角色管理", businessType = BusinessType.GRANT) @PostMapping("/authUser/selectAll") @ResponseBody public AjaxResult selectAuthUserAll(Long roleId, String userIds) { roleService.checkRoleDataScope(roleId); return toAjax(roleService.insertAuthUsers(roleId, userIds)); } /** * 加载角色部门(数据权限)列表树 */ @RequiresPermissions("system:role:edit") @GetMapping("/deptTreeData") @ResponseBody public List deptTreeData(SysRole role) { List ztrees = deptService.roleDeptTreeData(role); return ztrees; } }