com.didiglobal.logi.security.controller.v1.RoleController Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of logi-security-spring-boot-starter Show documentation
Show all versions of logi-security-spring-boot-starter Show documentation
logi-security 提供项目大多都需要的一些基础功能(用户、角色、权限、登录、注册、操作记录)
package com.didiglobal.logi.security.controller.v1;
import com.didiglobal.logi.security.common.constant.Constants;
import com.didiglobal.logi.security.common.PagingData;
import com.didiglobal.logi.security.common.PagingResult;
import com.didiglobal.logi.security.common.Result;
import com.didiglobal.logi.security.common.vo.role.AssignInfoVO;
import com.didiglobal.logi.security.common.dto.role.RoleAssignDTO;
import com.didiglobal.logi.security.common.dto.role.RoleQueryDTO;
import com.didiglobal.logi.security.common.dto.role.RoleSaveDTO;
import com.didiglobal.logi.security.common.vo.role.RoleBriefVO;
import com.didiglobal.logi.security.common.vo.role.RoleDeleteCheckVO;
import com.didiglobal.logi.security.common.vo.role.RoleVO;
import com.didiglobal.logi.security.exception.LogiSecurityException;
import com.didiglobal.logi.security.service.RoleService;
import io.swagger.annotations.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;
import java.util.List;
/**
* @author cjm
*/
@RestController
@Api(value = "logi-security-role相关API接口", tags = "logi-security-角色相关API接口")
@RequestMapping(Constants.API_PREFIX_V1 + "/role")
public class RoleController {
@Autowired
private RoleService roleService;
@GetMapping("/{id}")
@ApiOperation(value = "获取角色详情", notes = "根据角色id或角色code获取角色详情")
@ApiImplicitParam(name = "id", value = "角色id", dataType = "int", required = true)
public Result detail(@PathVariable Integer id) {
RoleVO roleVo = roleService.getRoleDetailByRoleId(id);
return Result.success(roleVo);
}
@PutMapping
@ApiOperation(value = "更新角色信息", notes = "根据角色id更新角色信息")
public Result update(@RequestBody RoleSaveDTO saveDTO, HttpServletRequest request) {
try {
roleService.updateRole(saveDTO, request);
return Result.success();
} catch (LogiSecurityException e) {
return Result.fail(e);
}
}
@PostMapping
@ApiOperation(value = "创建角色", notes = "创建角色")
public Result create(@RequestBody RoleSaveDTO saveDTO, HttpServletRequest request) {
try {
roleService.createRole(saveDTO, request);
return Result.success();
} catch (LogiSecurityException e) {
return Result.fail(e);
}
}
@DeleteMapping("/delete/check/{id}")
@ApiOperation(value = "删除角色前的检查", notes = "判断该角色是否已经分配给用户,如有分配给用户,则返回用户的信息list")
@ApiImplicitParam(name = "id", value = "角色id", dataType = "int", required = true)
public Result check(@PathVariable Integer id) {
return Result.success(roleService.checkBeforeDelete(id));
}
@DeleteMapping("/{id}/user/{userId}")
@ApiOperation(value = "从角色中删除该角色下的用户", notes = "从角色中删除该角色下的用户")
@ApiImplicitParam(name = "id", value = "角色id", dataType = "int", required = true)
public Result deleteUser(@PathVariable Integer id, @PathVariable Integer userId, HttpServletRequest request) {
try {
roleService.deleteUserFromRole(id, userId, request);
} catch (LogiSecurityException e) {
return Result.fail(e);
}
return Result.success();
}
@DeleteMapping("/{id}")
@ApiOperation(value = "删除角色", notes = "根据角色id删除角色")
@ApiImplicitParam(name = "id", value = "角色id", dataType = "int", required = true)
public Result delete(@PathVariable Integer id, HttpServletRequest request) {
try {
roleService.deleteRoleByRoleId(id, request);
} catch (LogiSecurityException e) {
return Result.fail(e);
}
return Result.success();
}
@PostMapping("/page")
@ApiOperation(value = "分页查询角色列表", notes = "分页和条件查询")
public PagingResult page(@RequestBody RoleQueryDTO queryDTO) {
PagingData pageRole = roleService.getRolePage(queryDTO);
return PagingResult.success(pageRole);
}
@PostMapping("/assign")
@ApiOperation(value = "分配角色", notes = "分配一个角色给多个用户或分配多个角色给一个用户")
public Result assign(@RequestBody RoleAssignDTO assignDTO, HttpServletRequest request) {
try {
roleService.assignRoles(assignDTO, request);
return Result.success();
} catch (LogiSecurityException e) {
return Result.fail(e);
}
}
@GetMapping(value = "/assign/list/{roleId}")
@ApiOperation(value = "角色管理/分配用户/列表", notes = "查询所有用户列表,并根据角色id,标记哪些用户拥有该角色")
@ApiImplicitParam(name = "roleId", value = "角色id", dataType = "int", required = true)
public Result> assignList(@PathVariable Integer roleId) {
List assignInfoVOList = roleService.getAssignInfoByRoleId(roleId);
return Result.success(assignInfoVOList);
}
@GetMapping(value = {"/list/{roleName}", "/list"})
@ApiOperation(value = "根据角色名模糊查询", notes = "用户管理/列表查询条件/分配角色框,这里会用到此接口")
@ApiImplicitParam(name = "roleName", value = "角色名(为null,查询全部)", dataType = "String")
public Result> list(@PathVariable(required = false) String roleName) {
List roleBriefVOList = roleService.getRoleBriefListByRoleName(roleName);
return Result.success(roleBriefVOList);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy