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> page(@Parameter(hidden = true) @RequestParam Map params) { PageData page = sysUserService.page(params); return new Result>().ok(page); } @GetMapping("{id}") @Operation(summary = "信息") @RequiresPermissions("sys:user:info") public Result get(@PathVariable("id") Long id) { SysUserDTO data = sysUserService.get(id); //用户角色列表 List roleIdList = sysRoleUserService.getRoleIdList(id); data.setRoleIdList(roleIdList); return new Result().ok(data); } @GetMapping("info") @Operation(summary = "登录用户信息") public Result info() { SysUserDTO data = ConvertUtils.sourceToTarget(SecurityUser.getUser(), SysUserDTO.class); return new Result().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 params, HttpServletResponse response) throws Exception { List list = sysUserService.list(params); ExcelUtils.exportExcelToTarget(response, null, "用户管理", list, SysUserExcel.class); } }