159 lines
5.6 KiB
Java
159 lines
5.6 KiB
Java
|
||
|
||
package io.modules.sys.controller;
|
||
|
||
import io.modules.security.password.PasswordUtils;
|
||
import io.modules.security.user.SecurityUser;
|
||
import io.modules.security.user.UserDetail;
|
||
import io.common.annotation.LogOperation;
|
||
import io.common.constant.Constant;
|
||
import io.common.exception.ErrorCode;
|
||
import io.common.page.PageData;
|
||
import io.common.utils.ConvertUtils;
|
||
import io.common.utils.ExcelUtils;
|
||
import io.common.utils.Result;
|
||
import io.common.validator.AssertUtils;
|
||
import io.common.validator.ValidatorUtils;
|
||
import io.common.validator.group.AddGroup;
|
||
import io.common.validator.group.DefaultGroup;
|
||
import io.common.validator.group.UpdateGroup;
|
||
import io.modules.sys.dto.PasswordDTO;
|
||
import io.modules.sys.dto.SysUserDTO;
|
||
import io.modules.sys.excel.SysUserExcel;
|
||
import io.modules.sys.service.SysRoleUserService;
|
||
import io.modules.sys.service.SysUserService;
|
||
import io.swagger.v3.oas.annotations.Operation;
|
||
import io.swagger.v3.oas.annotations.Parameter;
|
||
import io.swagger.v3.oas.annotations.Parameters;
|
||
import io.swagger.v3.oas.annotations.enums.ParameterIn;
|
||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||
import jakarta.servlet.http.HttpServletResponse;
|
||
import lombok.AllArgsConstructor;
|
||
import org.apache.shiro.authz.annotation.RequiresPermissions;
|
||
import org.springframework.web.bind.annotation.*;
|
||
|
||
import java.util.Arrays;
|
||
import java.util.List;
|
||
import java.util.Map;
|
||
|
||
/**
|
||
* 用户管理
|
||
*
|
||
|
||
*/
|
||
@RestController
|
||
@RequestMapping("/sys/user")
|
||
@Tag(name = "用户管理")
|
||
@AllArgsConstructor
|
||
public class SysUserController {
|
||
private final SysUserService sysUserService;
|
||
private final SysRoleUserService sysRoleUserService;
|
||
|
||
@GetMapping("page")
|
||
@Operation(summary = "分页")
|
||
@Parameters({
|
||
@Parameter(name = Constant.PAGE, description = "当前页码,从1开始", in = ParameterIn.QUERY, required = true, ref = "int"),
|
||
@Parameter(name = Constant.LIMIT, description = "每页显示记录数", in = ParameterIn.QUERY, required = true, ref = "int"),
|
||
@Parameter(name = Constant.ORDER_FIELD, description = "排序字段", in = ParameterIn.QUERY, ref = "String"),
|
||
@Parameter(name = Constant.ORDER, description = "排序方式,可选值(asc、desc)", in = ParameterIn.QUERY, ref = "String"),
|
||
@Parameter(name = "username", description = "用户名", in = ParameterIn.QUERY, ref = "String"),
|
||
@Parameter(name = "gender", description = "性别", in = ParameterIn.QUERY, ref = "String"),
|
||
@Parameter(name = "deptId", description = "部门ID", in = ParameterIn.QUERY, ref = "String")
|
||
})
|
||
@RequiresPermissions("sys:user:page")
|
||
public Result<PageData<SysUserDTO>> page(@Parameter(hidden = true) @RequestParam Map<String, Object> params) {
|
||
PageData<SysUserDTO> page = sysUserService.page(params);
|
||
|
||
return new Result<PageData<SysUserDTO>>().ok(page);
|
||
}
|
||
|
||
@GetMapping("{id}")
|
||
@Operation(summary = "信息")
|
||
@RequiresPermissions("sys:user:info")
|
||
public Result<SysUserDTO> get(@PathVariable("id") Long id) {
|
||
SysUserDTO data = sysUserService.get(id);
|
||
|
||
//用户角色列表
|
||
List<Long> roleIdList = sysRoleUserService.getRoleIdList(id);
|
||
data.setRoleIdList(roleIdList);
|
||
|
||
return new Result<SysUserDTO>().ok(data);
|
||
}
|
||
|
||
@GetMapping("info")
|
||
@Operation(summary = "登录用户信息")
|
||
public Result<SysUserDTO> info() {
|
||
SysUserDTO data = ConvertUtils.sourceToTarget(SecurityUser.getUser(), SysUserDTO.class);
|
||
return new Result<SysUserDTO>().ok(data);
|
||
}
|
||
|
||
@PutMapping("password")
|
||
@Operation(summary = "修改密码")
|
||
@LogOperation("修改密码")
|
||
public Result password(@RequestBody PasswordDTO dto) {
|
||
//效验数据
|
||
ValidatorUtils.validateEntity(dto);
|
||
|
||
UserDetail user = SecurityUser.getUser();
|
||
|
||
//原密码不正确
|
||
if (!PasswordUtils.matches(dto.getPassword(), user.getPassword())) {
|
||
return new Result().error("原密码不正确!");
|
||
}
|
||
|
||
sysUserService.updatePassword(user.getId(), dto.getNewPassword());
|
||
|
||
return new Result();
|
||
}
|
||
|
||
@PostMapping
|
||
@Operation(summary = "保存")
|
||
@LogOperation("保存")
|
||
@RequiresPermissions("sys:user:save")
|
||
public Result save(@RequestBody SysUserDTO dto) {
|
||
//效验数据
|
||
ValidatorUtils.validateEntity(dto, AddGroup.class, DefaultGroup.class);
|
||
|
||
sysUserService.save(dto);
|
||
|
||
return new Result();
|
||
}
|
||
|
||
@PutMapping
|
||
@Operation(summary = "修改")
|
||
@LogOperation("修改")
|
||
@RequiresPermissions("sys:user:update")
|
||
public Result update(@RequestBody SysUserDTO dto) {
|
||
//效验数据
|
||
ValidatorUtils.validateEntity(dto, UpdateGroup.class, DefaultGroup.class);
|
||
|
||
sysUserService.update(dto);
|
||
|
||
return new Result();
|
||
}
|
||
|
||
@DeleteMapping
|
||
@Operation(summary = "删除")
|
||
@LogOperation("删除")
|
||
@RequiresPermissions("sys:user:delete")
|
||
public Result delete(@RequestBody Long[] ids) {
|
||
//效验数据
|
||
AssertUtils.isArrayEmpty(ids, "id");
|
||
|
||
sysUserService.deleteBatchIds(Arrays.asList(ids));
|
||
|
||
return new Result();
|
||
}
|
||
|
||
@GetMapping("export")
|
||
@Operation(summary = "导出")
|
||
@LogOperation("导出")
|
||
@RequiresPermissions("sys:user:export")
|
||
@Parameter(name = "username", description = "用户名", in = ParameterIn.QUERY, ref = "String")
|
||
public void export(@Parameter(hidden = true) @RequestParam Map<String, Object> params, HttpServletResponse response) throws Exception {
|
||
List<SysUserDTO> list = sysUserService.list(params);
|
||
|
||
ExcelUtils.exportExcelToTarget(response, null, "用户管理", list, SysUserExcel.class);
|
||
}
|
||
}
|