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("分页") @ApiImplicitParams({ @ApiImplicitParam(name = Constant.PAGE, value = "当前页码,从1开始", paramType = "query", required = true, dataType="int") , @ApiImplicitParam(name = Constant.LIMIT, value = "每页显示记录数", paramType = "query",required = true, dataType="int") , @ApiImplicitParam(name = Constant.ORDER_FIELD, value = "排序字段", paramType = "query", dataType="String") , @ApiImplicitParam(name = Constant.ORDER, value = "排序方式,可选值(asc、desc)", paramType = "query", dataType="String") , @ApiImplicitParam(name = "name", value = "角色名", paramType = "query", dataType="String") }) @PreAuthorize("@ex.hasAuthority('sys:role:page')") public Result> page(@ApiIgnore @RequestParam Map params){ PageData page = sysRoleService.page(params); return new Result>().ok(page); } @GetMapping("list") @ApiOperation("列表") @PreAuthorize("@ex.hasAuthority('sys:role:list')") public Result> list(){ List data = sysRoleService.list(new HashMap<>(1)); return new Result>().ok(data); } @GetMapping("{id}") @ApiOperation("信息") @PreAuthorize("@ex.hasAuthority('sys:role:info')") public Result get(@PathVariable("id") Long id){ SysRoleDTO data = sysRoleService.get(id); //查询角色对应的菜单 List menuIdList = sysRoleMenuService.getMenuIdList(id); data.setMenuIdList(menuIdList); //查询角色对应的数据权限 List deptIdList = sysRoleDataScopeService.getDeptIdList(id); data.setDeptIdList(deptIdList); return new Result().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(); } }