package com.doumee.api.system; import com.doumee.core.model.ApiResponse; import com.doumee.api.BaseController; import com.doumee.biz.system.SystemUserBiz; import com.doumee.core.annotation.pr.PreventRepeat; import com.doumee.core.annotation.trace.Trace; import com.doumee.core.constants.OperaType; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.Constants; import com.doumee.dao.business.model.Member; import com.doumee.dao.system.dto.CreateSystemUserDTO; import com.doumee.dao.system.dto.CreateUserRoleDTO; import com.doumee.dao.system.dto.QuerySystemUserDTO; import com.doumee.dao.system.dto.ResetSystemUserPwdDTO; import com.doumee.dao.system.model.SystemUser; import com.doumee.dao.system.vo.SystemUserListVO; import com.doumee.service.system.SystemUserService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; import java.util.ArrayList; import java.util.List; /** * @author Eva.Caesar Liu * @date 2023/03/21 14:49 */ @Api(tags = "用户") @RestController @RequestMapping("/system/user") public class SystemUserController extends BaseController { @Autowired private SystemUserService systemUserService; @Autowired private SystemUserBiz systemUserBiz; @PreventRepeat @ApiOperation("配置用户角色") @PostMapping("/createUserRole") @RequiresPermissions("system:user:createUserRole") public ApiResponse createUserRole (@Validated @RequestBody CreateUserRoleDTO dto) { systemUserBiz.createUserRole(dto); return ApiResponse.success(null); } @Trace(withRequestParameters = false) @PreventRepeat @ApiOperation("重置用户密码") @PostMapping("/resetPwd") @RequiresPermissions("system:user:resetPwd") public ApiResponse resetPwd (@Validated @RequestBody ResetSystemUserPwdDTO dto) { dto.setOperaUserId(this.getLoginUser().getId()); systemUserBiz.resetPwd(dto); return ApiResponse.success(null); } @Trace(withRequestParameters = false) @PreventRepeat @ApiOperation("新建") @PostMapping("/create") @RequiresPermissions("system:user:create") public ApiResponse create(@Validated(OperaType.Create.class) @RequestBody CreateSystemUserDTO systemUser) { systemUser.setCreateUser(this.getLoginUser().getId()); systemUserBiz.create(systemUser); return ApiResponse.success(null); } @Trace(withRequestParameters = false) @PreventRepeat @ApiOperation("新建企业或者商户账号") @PostMapping("/createCompany") @RequiresPermissions("system:user:create") public ApiResponse createCompany(@Validated(OperaType.Create.class) @RequestBody CreateSystemUserDTO systemUser) { systemUser.setCreateUser(this.getLoginUser().getId()); systemUserBiz.createCompany(systemUser); return ApiResponse.success(null); } @PreventRepeat @ApiOperation("修改用户状态") @GetMapping("/updUserStatus") @RequiresPermissions("system:user:update") public ApiResponse updUserStatus( @RequestParam Integer id,@RequestParam Integer status) { systemUserBiz.updUserStatus(id,status); return ApiResponse.success(null); } @ApiOperation("删除") @GetMapping("/delete/{id}") @RequiresPermissions("system:user:delete") public ApiResponse deleteById(@PathVariable Integer id) { systemUserBiz.deleteById(id); return ApiResponse.success(null); } @ApiOperation("批量删除") @GetMapping("/delete/batch") @RequiresPermissions("system:user:delete") public ApiResponse deleteByIdInBatch(@RequestParam String ids) { String [] idArray = ids.split(","); List idList = new ArrayList<>(); for (String id : idArray) { idList.add(Integer.valueOf(id)); } systemUserBiz.deleteByIdInBatch(idList); return ApiResponse.success(null); } @Trace(withRequestParameters = false) @ApiOperation("修改") @PostMapping("/updateById") @RequiresPermissions("system:user:update") public ApiResponse updateById( @RequestBody CreateSystemUserDTO systemUser) { systemUser.setUpdateUser(this.getLoginUser().getId()); systemUserBiz.updateById(systemUser); return ApiResponse.success(null); } @ApiOperation("分页查询") @PostMapping("/page") @RequiresPermissions("system:user:query") public ApiResponse> findPage (@RequestBody PageWrap pageWrap) { return ApiResponse.success(systemUserService.findPage(pageWrap)); } @ApiOperation("分页查询") @PostMapping("/pageCompany") @RequiresPermissions("system:user:query") public ApiResponse> findPageCompany (@RequestBody PageWrap pageWrap) { return ApiResponse.success(systemUserService.findPageCompany(pageWrap)); } @ApiOperation("分页查询系统用户") @PostMapping("/findAllPage") @RequiresPermissions("system:user:query") public ApiResponse> findAllPage (@RequestBody PageWrap pageWrap) { return ApiResponse.success(systemUserService.findAllList(pageWrap)); } @ApiOperation("查询系统用户") @PostMapping("/findAllList") @RequiresPermissions("system:user:query") public ApiResponse> findAllList (@RequestBody SystemUser pageWrap) { return ApiResponse.success(systemUserService.findAllList(pageWrap)); } @ApiOperation("根据ID查询") @GetMapping("/{id}") @RequiresPermissions("system:user:query") public ApiResponse findById(@PathVariable Integer id) { return ApiResponse.success(systemUserService.findById(id)); } @ApiOperation("设置或取消主管") @PostMapping("/updateHead") @RequiresPermissions("system:user:query") public ApiResponse updateHead(@RequestBody SystemUser systemUser){ systemUserService.updateHead(systemUser); return ApiResponse.success(null); } }