2022-06-20 16:26:51 +08:00
|
|
|
|
package com.cnbm.admin.controller;
|
|
|
|
|
|
|
|
|
|
import com.cnbm.admin.annotation.LogOperation;
|
|
|
|
|
import com.cnbm.admin.dto.SysRoleDTO;
|
|
|
|
|
import com.cnbm.admin.service.SysRoleDataScopeService;
|
|
|
|
|
import com.cnbm.admin.service.SysRoleMenuService;
|
|
|
|
|
import com.cnbm.admin.service.SysRoleService;
|
|
|
|
|
import com.cnbm.common.constant.Constant;
|
|
|
|
|
import com.cnbm.common.page.PageData;
|
|
|
|
|
import com.cnbm.common.utils.Result;
|
|
|
|
|
import com.cnbm.common.validator.AssertUtils;
|
|
|
|
|
import com.cnbm.common.validator.ValidatorUtils;
|
|
|
|
|
import com.cnbm.common.validator.group.AddGroup;
|
|
|
|
|
import com.cnbm.common.validator.group.DefaultGroup;
|
|
|
|
|
import com.cnbm.common.validator.group.UpdateGroup;
|
|
|
|
|
import io.swagger.annotations.Api;
|
|
|
|
|
import io.swagger.annotations.ApiImplicitParam;
|
|
|
|
|
import io.swagger.annotations.ApiImplicitParams;
|
|
|
|
|
import io.swagger.annotations.ApiOperation;
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
|
import org.springframework.security.access.prepost.PreAuthorize;
|
|
|
|
|
import org.springframework.web.bind.annotation.*;
|
|
|
|
|
import springfox.documentation.annotations.ApiIgnore;
|
|
|
|
|
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
|
import java.util.List;
|
|
|
|
|
import java.util.Map;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @Author weihongyang
|
|
|
|
|
* @Date 2022/6/12 10:04 AM
|
|
|
|
|
* @Version 1.0
|
|
|
|
|
*/
|
|
|
|
|
@RestController
|
|
|
|
|
@RequestMapping("/sys/role")
|
|
|
|
|
@Api(tags="角色管理")
|
|
|
|
|
public class SysRoleController {
|
|
|
|
|
@Autowired
|
|
|
|
|
private SysRoleService sysRoleService;
|
|
|
|
|
@Autowired
|
|
|
|
|
private SysRoleMenuService sysRoleMenuService;
|
|
|
|
|
@Autowired
|
|
|
|
|
private SysRoleDataScopeService sysRoleDataScopeService;
|
|
|
|
|
|
|
|
|
|
@GetMapping("page")
|
|
|
|
|
@ApiOperation("分页")
|
2022-12-07 16:56:47 +08:00
|
|
|
|
// @ApiImplicitParams({
|
|
|
|
|
// @ApiImplicitParam(name = Constant.PAGE, value = "当前页码,从1开始", paramType = "query", required = true, dataTypeClass=Integer.class) ,
|
|
|
|
|
// @ApiImplicitParam(name = Constant.LIMIT, value = "每页显示记录数", paramType = "query",required = true, dataTypeClass=Integer.class) ,
|
|
|
|
|
// @ApiImplicitParam(name = Constant.ORDER_FIELD, value = "排序字段", paramType = "query", dataTypeClass=String.class) ,
|
|
|
|
|
// @ApiImplicitParam(name = Constant.ORDER, value = "排序方式,可选值(asc、desc)", paramType = "query", dataTypeClass=String.class) ,
|
|
|
|
|
// @ApiImplicitParam(name = "name", value = "角色名", paramType = "query", dataTypeClass=String.class)
|
|
|
|
|
// })
|
2022-06-20 16:26:51 +08:00
|
|
|
|
@PreAuthorize("@ex.hasAuthority('sys:role:page')")
|
|
|
|
|
public Result<PageData<SysRoleDTO>> page(@ApiIgnore @RequestParam Map<String, Object> params){
|
|
|
|
|
PageData<SysRoleDTO> page = sysRoleService.page(params);
|
|
|
|
|
|
|
|
|
|
return new Result<PageData<SysRoleDTO>>().ok(page);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@GetMapping("list")
|
|
|
|
|
@ApiOperation("列表")
|
|
|
|
|
@PreAuthorize("@ex.hasAuthority('sys:role:list')")
|
|
|
|
|
public Result<List<SysRoleDTO>> list(){
|
|
|
|
|
List<SysRoleDTO> data = sysRoleService.list(new HashMap<>(1));
|
|
|
|
|
|
|
|
|
|
return new Result<List<SysRoleDTO>>().ok(data);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@GetMapping("{id}")
|
|
|
|
|
@ApiOperation("信息")
|
|
|
|
|
@PreAuthorize("@ex.hasAuthority('sys:role:info')")
|
|
|
|
|
public Result<SysRoleDTO> get(@PathVariable("id") Long id){
|
|
|
|
|
SysRoleDTO data = sysRoleService.get(id);
|
|
|
|
|
|
|
|
|
|
//查询角色对应的菜单
|
|
|
|
|
List<Long> menuIdList = sysRoleMenuService.getMenuIdList(id);
|
|
|
|
|
data.setMenuIdList(menuIdList);
|
|
|
|
|
|
|
|
|
|
//查询角色对应的数据权限
|
|
|
|
|
List<Long> deptIdList = sysRoleDataScopeService.getDeptIdList(id);
|
|
|
|
|
data.setDeptIdList(deptIdList);
|
|
|
|
|
|
|
|
|
|
return new Result<SysRoleDTO>().ok(data);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@PostMapping
|
|
|
|
|
@ApiOperation("保存")
|
|
|
|
|
@LogOperation("保存")
|
|
|
|
|
@PreAuthorize("@ex.hasAuthority('sys:role:save')")
|
|
|
|
|
public Result save(@RequestBody SysRoleDTO dto){
|
|
|
|
|
//效验数据
|
|
|
|
|
ValidatorUtils.validateEntity(dto, AddGroup.class, DefaultGroup.class);
|
|
|
|
|
|
|
|
|
|
sysRoleService.save(dto);
|
|
|
|
|
|
|
|
|
|
return new Result();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@PutMapping
|
|
|
|
|
@ApiOperation("修改")
|
|
|
|
|
@LogOperation("修改")
|
|
|
|
|
@PreAuthorize("@ex.hasAuthority('sys:role:update')")
|
|
|
|
|
public Result update(@RequestBody SysRoleDTO dto){
|
|
|
|
|
//效验数据
|
|
|
|
|
ValidatorUtils.validateEntity(dto, UpdateGroup.class, DefaultGroup.class);
|
|
|
|
|
|
|
|
|
|
sysRoleService.update(dto);
|
|
|
|
|
|
|
|
|
|
return new Result();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@DeleteMapping
|
|
|
|
|
@ApiOperation("删除")
|
|
|
|
|
@LogOperation("删除")
|
|
|
|
|
@PreAuthorize("@ex.hasAuthority('sys:role:delete')")
|
|
|
|
|
public Result delete(@RequestBody Long[] ids){
|
|
|
|
|
//效验数据
|
|
|
|
|
AssertUtils.isArrayEmpty(ids, "id");
|
|
|
|
|
|
|
|
|
|
sysRoleService.delete(ids);
|
|
|
|
|
|
|
|
|
|
return new Result();
|
|
|
|
|
}
|
|
|
|
|
}
|