/** 
 | 
 * Copyright (c) 2018 人人开源 All rights reserved. 
 | 
 * 
 | 
 * https://www.renren.io 
 | 
 * 
 | 
 * 版权所有,侵权必究! 
 | 
 */ 
 | 
  
 | 
package com.zt.modules.sys.controller; 
 | 
  
 | 
import com.zt.common.annotation.LogOperation; 
 | 
import com.zt.common.annotation.QueryParam; 
 | 
import com.zt.common.constant.Constant; 
 | 
import com.zt.common.db.query.QueryFilter; 
 | 
import com.zt.common.servlet.PageResult; 
 | 
import com.zt.common.servlet.Result; 
 | 
import com.zt.common.validator.AssertUtils; 
 | 
import com.zt.common.validator.ValidatorUtils; 
 | 
import com.zt.common.validator.group.AddGroup; 
 | 
import com.zt.common.validator.group.DefaultGroup; 
 | 
import com.zt.common.validator.group.UpdateGroup; 
 | 
import com.zt.core.sys.model.SysUser; 
 | 
import com.zt.modules.sys.dto.RoleDataScopeDto; 
 | 
import com.zt.modules.sys.dto.RoleMenuDto; 
 | 
import com.zt.modules.sys.dto.UserDto; 
 | 
import com.zt.modules.sys.model.SysRole; 
 | 
import com.zt.modules.sys.model.SysRoleDataScope; 
 | 
import com.zt.modules.sys.model.SysRoleMenu; 
 | 
import com.zt.modules.sys.model.SysRoleUser; 
 | 
import com.zt.modules.sys.service.*; 
 | 
import io.swagger.annotations.Api; 
 | 
import io.swagger.annotations.ApiImplicitParam; 
 | 
import io.swagger.annotations.ApiImplicitParams; 
 | 
import io.swagger.annotations.ApiOperation; 
 | 
import org.apache.shiro.authz.annotation.RequiresPermissions; 
 | 
import org.springframework.beans.factory.annotation.Autowired; 
 | 
import org.springframework.web.bind.annotation.*; 
 | 
import springfox.documentation.annotations.ApiIgnore; 
 | 
  
 | 
import java.util.List; 
 | 
  
 | 
/** 
 | 
 * 角色管理 
 | 
 * 
 | 
 * @author hehz 
 | 
 */ 
 | 
@RestController 
 | 
@RequestMapping("/sys/role") 
 | 
@Api(tags = "角色管理") 
 | 
public class SysRoleController { 
 | 
    @Autowired 
 | 
    private SysRoleService sysRoleService; 
 | 
  
 | 
    @Autowired 
 | 
    private SysRoleUserService sysRoleUserService; 
 | 
  
 | 
    @Autowired 
 | 
    private SysInterfaceService sysInterfaceService; 
 | 
  
 | 
    @Autowired 
 | 
    private SysRoleMenuService sysRoleMenuService; 
 | 
    @Autowired 
 | 
    private SysRoleDataScopeService sysRoleDataScopeService; 
 | 
  
 | 
    @GetMapping("page") 
 | 
    @ApiOperation("分页") 
 | 
    @ApiImplicitParams({ 
 | 
            @ApiImplicitParam(name = Constant.Q.PAGE, value = Constant.QV.PAGE, required = true, dataType = Constant.QT.INT), 
 | 
            @ApiImplicitParam(name = Constant.Q.LIMIT, value = Constant.QV.LIMIT, required = true, dataType = Constant.QT.INT), 
 | 
            @ApiImplicitParam(name = Constant.Q.ORDER_FIELD, value = Constant.QV.ORDER_FIELD, dataType = Constant.QT.STRING), 
 | 
            @ApiImplicitParam(name = Constant.Q.ORDER, value = Constant.QV.ORDER, dataType = Constant.QT.STRING), 
 | 
            @ApiImplicitParam(name = "name", value = "角色名", dataType = Constant.QT.STRING, format = "name^LK"), 
 | 
            @ApiImplicitParam(name = "companyId", value = "公司Id", required = true, dataType = Constant.QT.STRING, format = "company_id^EQ") }) 
 | 
    @RequiresPermissions("sys:role:page") 
 | 
    public PageResult<SysRole> page(@ApiIgnore @QueryParam QueryFilter queryFilter) { 
 | 
        List<SysRole> list = sysRoleService.page(queryFilter); 
 | 
        return PageResult.ok(list); 
 | 
    } 
 | 
  
 | 
    @GetMapping("list") 
 | 
    @ApiOperation("列表") 
 | 
    @RequiresPermissions("sys:role:list") 
 | 
    public Result<List<SysRole>> list(@QueryParam Long deptId) { 
 | 
        List<SysRole> data = sysRoleService.listWithParents(deptId); 
 | 
        return Result.ok(data); 
 | 
    } 
 | 
  
 | 
    @GetMapping("{id}") 
 | 
    @ApiOperation("信息") 
 | 
    @RequiresPermissions("sys:role:info") 
 | 
    public Result<SysRole> get(@PathVariable("id") Long id) { 
 | 
        SysRole data = sysRoleService.get(id); 
 | 
  
 | 
        return Result.ok(data); 
 | 
    } 
 | 
  
 | 
    @GetMapping("roleMenu") 
 | 
    @ApiOperation("权限") 
 | 
    public Result<List<SysRoleMenu>> roleMenu(){ 
 | 
        List<SysRoleMenu> sysRoleMenus = sysRoleMenuService.roleMenu(); 
 | 
        return Result.ok(sysRoleMenus); 
 | 
    } 
 | 
  
 | 
    @PostMapping 
 | 
    @ApiOperation("新增") 
 | 
    @LogOperation("角色管理--->新增") 
 | 
    @RequiresPermissions("sys:role") 
 | 
    public Result insert(@RequestBody SysRole entity) { 
 | 
        // 效验数据 
 | 
        ValidatorUtils.validateEntity(entity, AddGroup.class, DefaultGroup.class); 
 | 
  
 | 
        sysRoleService.insert(entity); 
 | 
  
 | 
        return Result.ok(); 
 | 
    } 
 | 
  
 | 
    @PutMapping 
 | 
    @ApiOperation("修改") 
 | 
    @LogOperation("角色管理--->修改") 
 | 
    @RequiresPermissions("sys:role:update") 
 | 
    public Result update(@RequestBody SysRole entity) { 
 | 
        // 效验数据 
 | 
        ValidatorUtils.validateEntity(entity, UpdateGroup.class, DefaultGroup.class); 
 | 
  
 | 
        sysRoleService.update(entity); 
 | 
  
 | 
        return Result.ok(); 
 | 
    } 
 | 
  
 | 
    @DeleteMapping 
 | 
    @ApiOperation("删除") 
 | 
    @LogOperation("角色管理--->删除") 
 | 
    @RequiresPermissions("sys:role:delete") 
 | 
    public Result delete(@RequestBody Long[] ids) { 
 | 
        // 效验数据 
 | 
        AssertUtils.isArrayEmpty(ids, "id"); 
 | 
  
 | 
        sysRoleService.delete(ids); 
 | 
  
 | 
        return Result.ok(); 
 | 
    } 
 | 
  
 | 
    @GetMapping("menu") 
 | 
    @ApiOperation("获取菜单权限") 
 | 
    @RequiresPermissions("sys:role:info") 
 | 
    public Result<List<Long>> getRoleMenu(@QueryParam Long roleId) { 
 | 
  
 | 
        return Result.ok(sysRoleMenuService.getRoleMenuIds(roleId)); 
 | 
    } 
 | 
  
 | 
    @PostMapping("menu") 
 | 
    @ApiOperation("配置菜单权限") 
 | 
    @RequiresPermissions("sys:role:menu") 
 | 
    public Result setRoleMenu(@RequestBody RoleMenuDto entity) { 
 | 
  
 | 
        // 效验数据 
 | 
        ValidatorUtils.validateEntity(entity, UpdateGroup.class, DefaultGroup.class); 
 | 
        sysRoleMenuService.saveOrUpdate(entity.getRoleId(), entity.getMenuIdList()); 
 | 
  
 | 
        return Result.ok(); 
 | 
    } 
 | 
  
 | 
    @GetMapping("dataScope") 
 | 
    @ApiOperation("获取角色数据权限") 
 | 
    @RequiresPermissions("sys:role:info") 
 | 
    public Result<List<SysRoleDataScope>> getRoleDataScope(@QueryParam Long roleId) { 
 | 
  
 | 
        return Result.ok(sysRoleDataScopeService.getByRoleId(roleId)); 
 | 
    } 
 | 
  
 | 
    @PostMapping("dataScope") 
 | 
    @ApiOperation("配置角色数据权限") 
 | 
    @RequiresPermissions("sys:role:dataScope") 
 | 
    public Result setRoleDataScope(@RequestBody RoleDataScopeDto entity) { 
 | 
  
 | 
        // 效验数据 
 | 
        ValidatorUtils.validateEntity(entity, UpdateGroup.class, DefaultGroup.class); 
 | 
        sysRoleDataScopeService.saveOrUpdate(entity.getRoleId(), entity.getDataScopeList()); 
 | 
  
 | 
        return Result.ok(); 
 | 
    } 
 | 
  
 | 
    @GetMapping("roleUsers") 
 | 
    @ApiOperation("获取角色人员") 
 | 
    @RequiresPermissions("sys:role:info") 
 | 
    public PageResult<SysUser> getUserRoles(@QueryParam Long roleId) { 
 | 
        List<SysUser> list = sysRoleService.getRoleUsers(roleId); 
 | 
        return PageResult.ok(list); 
 | 
    } 
 | 
  
 | 
    @PostMapping("addroleuser") 
 | 
    @ApiOperation("添加角色人员") 
 | 
    @LogOperation("角色管理--->添加角色人员") 
 | 
    @RequiresPermissions("sys:role:update") 
 | 
    public Result addRoleUser(@RequestBody RoleMenuDto model) { 
 | 
  
 | 
        sysRoleUserService.addRoleUser(model.getRoleId(),model.getMenuIdList()); 
 | 
  
 | 
        return Result.ok(); 
 | 
    } 
 | 
  
 | 
    @PostMapping("deleteRoleUsers") 
 | 
    @ApiOperation("删除角色用户") 
 | 
    @LogOperation("角色管理--->删除角色用户") 
 | 
    public Result deleteRoleUsers(@RequestBody SysRoleUser model) { 
 | 
        List<SysRoleUser> list = sysRoleUserService.getSingleRoleUsers(model.getRoleId(), model.getUserId()); 
 | 
        sysRoleUserService.deleteLogic(list); 
 | 
        return Result.ok(); 
 | 
    } 
 | 
  
 | 
  
 | 
} 
 |