package com.xunmei.system.controller; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.xunmei.common.core.domain.IdName; import com.xunmei.common.core.vo.IdNameVo; import com.xunmei.common.core.web.controller.BaseController; import com.xunmei.common.core.web.domain.AjaxResult; import com.xunmei.common.core.web.page.TableDataInfo; import com.xunmei.common.log.annotation.Log; import com.xunmei.common.log.enums.BusinessType; import com.xunmei.common.security.annotation.InnerAuth; import com.xunmei.common.security.annotation.RequiresPermissions; import com.xunmei.common.security.utils.SecurityUtils; import com.xunmei.system.api.Eto.RoleConditionEto; import com.xunmei.system.api.domain.SysDept; import com.xunmei.system.api.domain.SysRole; import com.xunmei.system.api.domain.SysUser; import com.xunmei.system.domain.SysUserRole; import com.xunmei.system.service.ISysDeptService; import com.xunmei.system.service.ISysRoleService; import com.xunmei.system.service.ISysUserService; import io.swagger.annotations.ApiOperation; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; import java.util.List; import java.util.stream.Collectors; /** * 角色信息 * * @author xunmei */ @RestController @RequestMapping("/role") public class SysRoleController extends BaseController { @Autowired private ISysRoleService roleService; @Autowired private ISysUserService userService; @Autowired private ISysDeptService deptService; @RequiresPermissions("system:role:list") @GetMapping("/list") public TableDataInfo list(SysRole role) { return roleService.selectRoleList(role); } /** * 根据角色编号获取详细信息 */ @RequiresPermissions("system:role:query") @GetMapping(value = "/{roleId}") public AjaxResult getInfo(@PathVariable Long roleId) { roleService.checkRoleDataScope(roleId); return success(roleService.selectRoleById(roleId)); } /** * 新增角色 */ @RequiresPermissions("system:role:add") @Log(title = "角色管理", businessType = BusinessType.INSERT) @PostMapping public AjaxResult add(@Validated @RequestBody SysRole role) { if (!roleService.checkRoleNameUnique(role)) { return error("新增角色'" + role.getRoleName() + "'失败,角色名称已存在"); } else if (!roleService.checkRoleKeyUnique(role)) { return error("新增角色'" + role.getRoleName() + "'失败,角色权限已存在"); } role.setCreateBy(SecurityUtils.getUsername()); return toAjax(roleService.insertRole(role)); } /** * 修改保存角色 */ @RequiresPermissions("system:role:edit") @Log(title = "角色管理", businessType = BusinessType.UPDATE) @PutMapping public AjaxResult edit(@Validated @RequestBody SysRole role) { roleService.checkRoleAllowed(role); roleService.checkRoleDataScope(role.getId()); if (!roleService.checkRoleNameUnique(role)) { return error("修改角色'" + role.getRoleName() + "'失败,角色名称已存在"); } /* else if (!roleService.checkRoleKeyUnique(role)) { return error("修改角色'" + role.getRoleName() + "'失败,角色权限已存在"); }*/ role.setUpdateBy(SecurityUtils.getUsername()); return toAjax(roleService.updateRole(role)); } /** * 修改保存数据权限 */ @RequiresPermissions("system:role:edit") @Log(title = "角色管理", businessType = BusinessType.UPDATE) @PutMapping("/dataScope") public AjaxResult dataScope(@RequestBody SysRole role) { roleService.checkRoleAllowed(role); roleService.checkRoleDataScope(role.getId()); return toAjax(roleService.authDataScope(role)); } /** * 状态修改 */ @RequiresPermissions("system:role:edit") @Log(title = "角色管理", businessType = BusinessType.UPDATE) @PutMapping("/changeStatus") public AjaxResult changeStatus(@RequestBody SysRole role) { roleService.checkRoleAllowed(role); roleService.checkRoleDataScope(role.getId()); role.setUpdateBy(SecurityUtils.getUsername()); return toAjax(roleService.updateRoleStatus(role)); } /** * 删除角色 */ @RequiresPermissions("system:role:remove") @Log(title = "角色管理", businessType = BusinessType.DELETE) @DeleteMapping("/{ids}") public AjaxResult remove(@PathVariable Long[] ids) { return toAjax(roleService.deleteRoleByIds(ids)); } /** * 获取角色选择框列表 */ @RequiresPermissions("system:role:query") @GetMapping("/optionselect") public AjaxResult optionselect() { return success(roleService.selectRoleAll()); } @RequiresPermissions("system:role:query") @GetMapping("/allRole") public AjaxResult allRole() { return success(roleService.allRole()); } /** * 查询已分配用户角色列表 */ /* @RequiresPermissions("system:role:list") @GetMapping("/authUser/allocatedList") public TableDataInfo allocatedList(SysUserVO user) { return userService.selectAllocatedList(user); } *//** * 查询未分配用户角色列表 *//* @RequiresPermissions("system:role:list") @GetMapping("/authUser/unallocatedList") public TableDataInfo unallocatedList(SysUserVO user) { return userService.selectUnallocatedList(user); } */ /** * 取消授权用户 */ @RequiresPermissions("system:role:edit") @Log(title = "角色管理", businessType = BusinessType.GRANT) @PutMapping("/authUser/cancel") public AjaxResult cancelAuthUser(@RequestBody SysUserRole userRole) { return toAjax(roleService.deleteAuthUser(userRole)); } /** * 批量取消授权用户 */ @RequiresPermissions("system:role:edit") @Log(title = "角色管理", businessType = BusinessType.GRANT) @PutMapping("/authUser/cancelAll") public AjaxResult cancelAuthUserAll(Long roleId, Long[] userIds) { return toAjax(roleService.deleteAuthUsers(roleId, userIds)); } /** * 批量选择用户授权 */ @RequiresPermissions("system:role:edit") @Log(title = "角色管理", businessType = BusinessType.GRANT) @PutMapping("/authUser/selectAll") public AjaxResult selectAuthUserAll(Long roleId, Long[] userIds) { roleService.checkRoleDataScope(roleId); return toAjax(roleService.insertAuthUsers(roleId, userIds)); } /** * 获取对应角色机构树列表 */ @RequiresPermissions("system:role:query") @GetMapping(value = "/deptTree/{roleId}") public AjaxResult deptTree(@PathVariable("roleId") Long roleId) { AjaxResult ajax = AjaxResult.success(); ajax.put("checkedKeys", deptService.selectDeptListByRoleId(roleId)); ajax.put("depts", deptService.selectDeptTreeList(new SysDept())); return ajax; } /** * 获取所有可用的角色信息 */ @GetMapping(value = "/all") public AjaxResult all(@RequestParam(value = "orgType", required = false) Integer orgType) { return success(roleService.selectSimpleRoleAll(null, orgType)); } @ApiOperation(value = "根据id查询角色") @InnerAuth @GetMapping(value = "/getRoleById") public SysRole getRoleById(Long id) { return roleService.getById(id); } @ApiOperation(value = "根据userid查询角色") @InnerAuth @GetMapping(value = "/getRoleByUserId") public List getRoleByUserId(Long userId) { return roleService.selectRolesByUserId(userId); } @ApiOperation(value = "根据名称查询角色") @InnerAuth @GetMapping(value = "/getRoleByName") public SysRole getRoleByName(String name) { return roleService.getOne(new LambdaQueryWrapper() .like(SysRole::getRoleName, name).select(SysRole::getId)); } /** * 根据用户查询角色 * * @param userId * @return */ @InnerAuth @GetMapping(value = "/selectRoleNameByUserId") public String selectRoleNameByUserId(Long userId) { return roleService.selectRoleNameByUserId(userId); } @RequiresPermissions("system:role:query") @ApiOperation(value = "根据机构类型查询角色") @GetMapping(value = "/getRoleByType/{type}") public List getRoleByType(@PathVariable(value = "type", required = false) String type) { return roleService.getRoleByType(type); } // @InnerAuth @PostMapping("/getNames") public List getNames(@RequestBody RoleConditionEto condition) { List> r = roleService.selectSimpleRoleAll(condition, null); return r.stream().map(i -> new IdNameVo(i.getId(), i.getName(), null)).collect(Collectors.toList()); } @GetMapping("/getnamesbyorgid/{orgId}") public AjaxResult getNamesByOrgId(@PathVariable Long orgId) { return success(roleService.getNamesByOrgId(orgId)); } @GetMapping("/selectUserByRoleNameAndOrgId") public List selectUserByRoleNameAndOrgId(@RequestParam(value = "roleName") String roleName, @RequestParam(value = "orgId") Long orgId) { return roleService.selectUserByRoleNameAndOrgId(roleName, orgId); } @GetMapping("/getRoles") public List getRoles() { return roleService.getRoles(); } }