123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- package cn.iocoder.yudao.module.system.controller.admin.user;
- import org.springframework.web.bind.annotation.*;
- import javax.annotation.Resource;
- import org.springframework.validation.annotation.Validated;
- import org.springframework.security.access.prepost.PreAuthorize;
- import io.swagger.v3.oas.annotations.tags.Tag;
- import io.swagger.v3.oas.annotations.Parameter;
- import io.swagger.v3.oas.annotations.Operation;
- import javax.validation.constraints.*;
- import javax.validation.*;
- import javax.servlet.http.*;
- import java.util.*;
- import java.io.IOException;
- import cn.iocoder.yudao.framework.common.pojo.PageResult;
- import cn.iocoder.yudao.framework.common.pojo.CommonResult;
- import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
- import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
- import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
- import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.*;
- import cn.iocoder.yudao.module.system.controller.admin.user.vo.*;
- import cn.iocoder.yudao.module.system.dal.dataobject.user.SystemUserDO;
- import cn.iocoder.yudao.module.system.convert.user.SystemUserConvert;
- import cn.iocoder.yudao.module.system.service.user.SystemUserService;
- @Tag(name = "管理后台 - 用户")
- @RestController
- @RequestMapping("/system/user")
- @Validated
- public class SystemUserController {
- @Resource
- private SystemUserService userService;
- @PostMapping("/create")
- @Operation(summary = "创建用户")
- @PreAuthorize("@ss.hasPermission('system:user:create')")
- public CommonResult<Long> createUser(@Valid @RequestBody SystemUserCreateReqVO createReqVO) {
- return success(userService.createUser(createReqVO));
- }
- @PutMapping("/update")
- @Operation(summary = "更新用户")
- @PreAuthorize("@ss.hasPermission('system:user:update')")
- public CommonResult<Boolean> updateUser(@Valid @RequestBody SystemUserUpdateReqVO updateReqVO) {
- userService.updateUser(updateReqVO);
- return success(true);
- }
- @DeleteMapping("/delete")
- @Operation(summary = "删除用户")
- @Parameter(name = "id", description = "编号", required = true)
- @PreAuthorize("@ss.hasPermission('system:user:delete')")
- public CommonResult<Boolean> deleteUser(@RequestParam("id") Long id) {
- userService.deleteUser(id);
- return success(true);
- }
- @GetMapping("/get")
- @Operation(summary = "获得用户")
- @Parameter(name = "id", description = "编号", required = true, example = "1024")
- @PreAuthorize("@ss.hasPermission('system:user:query')")
- public CommonResult<SystemUserRespVO> getUser(@RequestParam("id") Long id) {
- SystemUserDO user = userService.getUser(id);
- return success(SystemUserConvert.INSTANCE.convert(user));
- }
- @GetMapping("/list")
- @Operation(summary = "获得用户列表")
- @Parameter(name = "ids", description = "编号列表", required = true, example = "1024,2048")
- @PreAuthorize("@ss.hasPermission('system:user:query')")
- public CommonResult<List<SystemUserRespVO>> getUserList(@RequestParam("ids") Collection<Long> ids) {
- List<SystemUserDO> list = userService.getUserList(ids);
- return success(SystemUserConvert.INSTANCE.convertList(list));
- }
- @GetMapping("/page")
- @Operation(summary = "获得用户分页")
- @PreAuthorize("@ss.hasPermission('system:user:query')")
- public CommonResult<PageResult<SystemUserRespVO>> getUserPage(@Valid SystemUserPageReqVO pageVO) {
- PageResult<SystemUserDO> pageResult = userService.getUserPage(pageVO);
- return success(SystemUserConvert.INSTANCE.convertPage(pageResult));
- }
- @GetMapping("/export-excel")
- @Operation(summary = "导出用户 Excel")
- @PreAuthorize("@ss.hasPermission('system:user:export')")
- @OperateLog(type = EXPORT)
- public void exportUserExcel(@Valid SystemUserExportReqVO exportReqVO,
- HttpServletResponse response) throws IOException {
- List<SystemUserDO> list = userService.getUserList(exportReqVO);
- // 导出 Excel
- List<SystemUserExcelVO> datas = SystemUserConvert.INSTANCE.convertList02(list);
- ExcelUtils.write(response, "用户.xls", "数据", SystemUserExcelVO.class, datas);
- }
- }
|