SysUserController.java 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. package com.ruoyi.web.controller.system;
  2. import cn.dev33.satoken.annotation.SaCheckPermission;
  3. import cn.dev33.satoken.secure.BCrypt;
  4. import cn.hutool.core.bean.BeanUtil;
  5. import cn.hutool.core.util.ArrayUtil;
  6. import cn.hutool.core.util.ObjectUtil;
  7. import com.ruoyi.common.annotation.Log;
  8. import com.ruoyi.common.constant.UserConstants;
  9. import com.ruoyi.common.core.controller.BaseController;
  10. import com.ruoyi.common.core.domain.PageQuery;
  11. import com.ruoyi.common.core.domain.R;
  12. import com.ruoyi.common.core.domain.entity.SysDept;
  13. import com.ruoyi.common.core.domain.entity.SysRole;
  14. import com.ruoyi.common.core.domain.entity.SysUser;
  15. import com.ruoyi.common.core.page.TableDataInfo;
  16. import com.ruoyi.common.enums.BusinessType;
  17. import com.ruoyi.common.excel.ExcelResult;
  18. import com.ruoyi.common.helper.LoginHelper;
  19. import com.ruoyi.common.utils.StringUtils;
  20. import com.ruoyi.common.utils.poi.ExcelUtil;
  21. import com.ruoyi.system.domain.vo.SysUserExportVo;
  22. import com.ruoyi.system.domain.vo.SysUserImportVo;
  23. import com.ruoyi.system.listener.SysUserImportListener;
  24. import com.ruoyi.system.service.ISysPostService;
  25. import com.ruoyi.system.service.ISysRoleService;
  26. import com.ruoyi.system.service.ISysUserService;
  27. import io.swagger.annotations.*;
  28. import lombok.RequiredArgsConstructor;
  29. import org.springframework.validation.annotation.Validated;
  30. import org.springframework.web.bind.annotation.*;
  31. import org.springframework.web.multipart.MultipartFile;
  32. import javax.servlet.http.HttpServletResponse;
  33. import java.util.ArrayList;
  34. import java.util.HashMap;
  35. import java.util.List;
  36. import java.util.Map;
  37. import java.util.stream.Collectors;
  38. /**
  39. * 用户信息
  40. *
  41. * @author Lion Li
  42. */
  43. @Validated
  44. @Api(value = "用户信息控制器", tags = {"用户信息管理"})
  45. @RequiredArgsConstructor
  46. @RestController
  47. @RequestMapping("/system/user")
  48. public class SysUserController extends BaseController {
  49. private final ISysUserService userService;
  50. private final ISysRoleService roleService;
  51. private final ISysPostService postService;
  52. /**
  53. * 获取用户列表
  54. */
  55. @ApiOperation("获取用户列表")
  56. @SaCheckPermission("system:user:list")
  57. @GetMapping("/list")
  58. public TableDataInfo<SysUser> list(SysUser user, PageQuery pageQuery) {
  59. return userService.selectPageUserList(user, pageQuery);
  60. }
  61. @ApiOperation("导出用户列表")
  62. @Log(title = "用户管理", businessType = BusinessType.EXPORT)
  63. @SaCheckPermission("system:user:export")
  64. @PostMapping("/export")
  65. public void export(SysUser user, HttpServletResponse response) {
  66. List<SysUser> list = userService.selectUserList(user);
  67. List<SysUserExportVo> listVo = BeanUtil.copyToList(list, SysUserExportVo.class);
  68. for (int i = 0; i < list.size(); i++) {
  69. SysDept dept = list.get(i).getDept();
  70. SysUserExportVo vo = listVo.get(i);
  71. if (ObjectUtil.isNotEmpty(dept)) {
  72. vo.setDeptName(dept.getDeptName());
  73. vo.setLeader(dept.getLeader());
  74. }
  75. }
  76. ExcelUtil.exportExcel(listVo, "用户数据", SysUserExportVo.class, response);
  77. }
  78. @ApiOperation("导入用户列表")
  79. @ApiImplicitParams({
  80. @ApiImplicitParam(name = "file", value = "导入文件", dataType = "java.io.File", required = true),
  81. })
  82. @Log(title = "用户管理", businessType = BusinessType.IMPORT)
  83. @SaCheckPermission("system:user:import")
  84. @PostMapping("/importData")
  85. public R<Void> importData(@RequestPart("file") MultipartFile file, boolean updateSupport) throws Exception {
  86. ExcelResult<SysUserImportVo> result = ExcelUtil.importExcel(file.getInputStream(), SysUserImportVo.class, new SysUserImportListener(updateSupport));
  87. return R.ok(result.getAnalysis());
  88. }
  89. @ApiOperation("下载导入模板")
  90. @PostMapping("/importTemplate")
  91. public void importTemplate(HttpServletResponse response) {
  92. ExcelUtil.exportExcel(new ArrayList<>(), "用户数据", SysUserImportVo.class, response);
  93. }
  94. /**
  95. * 根据用户编号获取详细信息
  96. */
  97. @ApiOperation("根据用户编号获取详细信息")
  98. @SaCheckPermission("system:user:query")
  99. @GetMapping(value = {"/", "/{userId}"})
  100. public R<Map<String, Object>> getInfo(@ApiParam("用户ID") @PathVariable(value = "userId", required = false) Long userId) {
  101. userService.checkUserDataScope(userId);
  102. Map<String, Object> ajax = new HashMap<>();
  103. List<SysRole> roles = roleService.selectRoleAll();
  104. ajax.put("roles", LoginHelper.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList()));
  105. ajax.put("posts", postService.selectPostAll());
  106. if (ObjectUtil.isNotNull(userId)) {
  107. SysUser sysUser = userService.selectUserById(userId);
  108. ajax.put("user", sysUser);
  109. ajax.put("postIds", postService.selectPostListByUserId(userId));
  110. ajax.put("roleIds", sysUser.getRoles().stream().map(SysRole::getRoleId).collect(Collectors.toList()));
  111. }
  112. return R.ok(ajax);
  113. }
  114. /**
  115. * 新增用户
  116. */
  117. @ApiOperation("新增用户")
  118. @SaCheckPermission("system:user:add")
  119. @Log(title = "用户管理", businessType = BusinessType.INSERT)
  120. @PostMapping
  121. public R<Void> add(@Validated @RequestBody SysUser user) {
  122. if (UserConstants.NOT_UNIQUE.equals(userService.checkUserNameUnique(user.getUserName()))) {
  123. return R.fail("新增用户'" + user.getUserName() + "'失败,登录账号已存在");
  124. } else if (StringUtils.isNotEmpty(user.getPhonenumber())
  125. && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) {
  126. return R.fail("新增用户'" + user.getUserName() + "'失败,手机号码已存在");
  127. } else if (StringUtils.isNotEmpty(user.getEmail())
  128. && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) {
  129. return R.fail("新增用户'" + user.getUserName() + "'失败,邮箱账号已存在");
  130. }
  131. user.setPassword(BCrypt.hashpw(user.getPassword()));
  132. return toAjax(userService.insertUser(user));
  133. }
  134. /**
  135. * 修改用户
  136. */
  137. @ApiOperation("修改用户")
  138. @SaCheckPermission("system:user:edit")
  139. @Log(title = "用户管理", businessType = BusinessType.UPDATE)
  140. @PutMapping
  141. public R<Void> edit(@Validated @RequestBody SysUser user) {
  142. userService.checkUserAllowed(user);
  143. userService.checkUserDataScope(user.getUserId());
  144. if (StringUtils.isNotEmpty(user.getPhonenumber())
  145. && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user))) {
  146. return R.fail("修改用户'" + user.getUserName() + "'失败,手机号码已存在");
  147. } else if (StringUtils.isNotEmpty(user.getEmail())
  148. && UserConstants.NOT_UNIQUE.equals(userService.checkEmailUnique(user))) {
  149. return R.fail("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在");
  150. }
  151. return toAjax(userService.updateUser(user));
  152. }
  153. /**
  154. * 删除用户
  155. */
  156. @ApiOperation("删除用户")
  157. @SaCheckPermission("system:user:remove")
  158. @Log(title = "用户管理", businessType = BusinessType.DELETE)
  159. @DeleteMapping("/{userIds}")
  160. public R<Void> remove(@ApiParam("角色ID串") @PathVariable Long[] userIds) {
  161. if (ArrayUtil.contains(userIds, getUserId())) {
  162. return R.fail("当前用户不能删除");
  163. }
  164. return toAjax(userService.deleteUserByIds(userIds));
  165. }
  166. /**
  167. * 重置密码
  168. */
  169. @ApiOperation("重置密码")
  170. @SaCheckPermission("system:user:resetPwd")
  171. @Log(title = "用户管理", businessType = BusinessType.UPDATE)
  172. @PutMapping("/resetPwd")
  173. public R<Void> resetPwd(@RequestBody SysUser user) {
  174. userService.checkUserAllowed(user);
  175. userService.checkUserDataScope(user.getUserId());
  176. user.setPassword(BCrypt.hashpw(user.getPassword()));
  177. return toAjax(userService.resetPwd(user));
  178. }
  179. /**
  180. * 状态修改
  181. */
  182. @ApiOperation("状态修改")
  183. @SaCheckPermission("system:user:edit")
  184. @Log(title = "用户管理", businessType = BusinessType.UPDATE)
  185. @PutMapping("/changeStatus")
  186. public R<Void> changeStatus(@RequestBody SysUser user) {
  187. userService.checkUserAllowed(user);
  188. userService.checkUserDataScope(user.getUserId());
  189. return toAjax(userService.updateUserStatus(user));
  190. }
  191. /**
  192. * 根据用户编号获取授权角色
  193. */
  194. @ApiOperation("根据用户编号获取授权角色")
  195. @SaCheckPermission("system:user:query")
  196. @GetMapping("/authRole/{userId}")
  197. public R<Map<String, Object>> authRole(@ApiParam("用户ID") @PathVariable("userId") Long userId) {
  198. SysUser user = userService.selectUserById(userId);
  199. List<SysRole> roles = roleService.selectRolesByUserId(userId);
  200. Map<String, Object> ajax = new HashMap<>();
  201. ajax.put("user", user);
  202. ajax.put("roles", LoginHelper.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList()));
  203. return R.ok(ajax);
  204. }
  205. /**
  206. * 用户授权角色
  207. */
  208. @ApiOperation("用户授权角色")
  209. @ApiImplicitParams({
  210. @ApiImplicitParam(name = "userId", value = "用户Id", paramType = "query", dataTypeClass = String.class),
  211. @ApiImplicitParam(name = "roleIds", value = "角色ID串", paramType = "query", dataTypeClass = String.class)
  212. })
  213. @SaCheckPermission("system:user:edit")
  214. @Log(title = "用户管理", businessType = BusinessType.GRANT)
  215. @PutMapping("/authRole")
  216. public R<Void> insertAuthRole(Long userId, Long[] roleIds) {
  217. userService.checkUserDataScope(userId);
  218. userService.insertUserAuth(userId, roleIds);
  219. return R.ok();
  220. }
  221. }