SysUserServiceImpl.java 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565
  1. package com.ruoyi.system.service.impl;
  2. import java.util.ArrayList;
  3. import java.util.Date;
  4. import java.util.List;
  5. import java.util.stream.Collectors;
  6. import jakarta.validation.Validator;
  7. import org.slf4j.Logger;
  8. import org.slf4j.LoggerFactory;
  9. import org.springframework.beans.factory.annotation.Autowired;
  10. import org.springframework.stereotype.Service;
  11. import org.springframework.transaction.annotation.Transactional;
  12. import org.springframework.util.CollectionUtils;
  13. import com.ruoyi.common.annotation.DataScope;
  14. import com.ruoyi.common.constant.UserConstants;
  15. import com.ruoyi.common.core.domain.entity.SysRole;
  16. import com.ruoyi.common.core.domain.entity.SysUser;
  17. import com.ruoyi.common.exception.ServiceException;
  18. import com.ruoyi.common.utils.SecurityUtils;
  19. import com.ruoyi.common.utils.StringUtils;
  20. import com.ruoyi.common.utils.bean.BeanValidators;
  21. import com.ruoyi.common.utils.spring.SpringUtils;
  22. import com.ruoyi.system.domain.SysPost;
  23. import com.ruoyi.system.domain.SysUserPost;
  24. import com.ruoyi.system.domain.SysUserRole;
  25. import com.ruoyi.system.mapper.SysPostMapper;
  26. import com.ruoyi.system.mapper.SysRoleMapper;
  27. import com.ruoyi.system.mapper.SysUserMapper;
  28. import com.ruoyi.system.mapper.SysUserPostMapper;
  29. import com.ruoyi.system.mapper.SysUserRoleMapper;
  30. import com.ruoyi.system.service.ISysConfigService;
  31. import com.ruoyi.system.service.ISysDeptService;
  32. import com.ruoyi.system.service.ISysUserService;
  33. /**
  34. * 用户 业务层处理
  35. *
  36. * @author ruoyi
  37. */
  38. @Service
  39. public class SysUserServiceImpl implements ISysUserService
  40. {
  41. private static final Logger log = LoggerFactory.getLogger(SysUserServiceImpl.class);
  42. @Autowired
  43. private SysUserMapper userMapper;
  44. @Autowired
  45. private SysRoleMapper roleMapper;
  46. @Autowired
  47. private SysPostMapper postMapper;
  48. @Autowired
  49. private SysUserRoleMapper userRoleMapper;
  50. @Autowired
  51. private SysUserPostMapper userPostMapper;
  52. @Autowired
  53. private ISysConfigService configService;
  54. @Autowired
  55. private ISysDeptService deptService;
  56. @Autowired
  57. protected Validator validator;
  58. /**
  59. * 根据条件分页查询用户列表
  60. *
  61. * @param user 用户信息
  62. * @return 用户信息集合信息
  63. */
  64. @Override
  65. @DataScope(deptAlias = "d", userAlias = "u")
  66. public List<SysUser> selectUserList(SysUser user)
  67. {
  68. return userMapper.selectUserList(user);
  69. }
  70. /**
  71. * 根据条件分页查询已分配用户角色列表
  72. *
  73. * @param user 用户信息
  74. * @return 用户信息集合信息
  75. */
  76. @Override
  77. @DataScope(deptAlias = "d", userAlias = "u")
  78. public List<SysUser> selectAllocatedList(SysUser user)
  79. {
  80. return userMapper.selectAllocatedList(user);
  81. }
  82. /**
  83. * 根据条件分页查询未分配用户角色列表
  84. *
  85. * @param user 用户信息
  86. * @return 用户信息集合信息
  87. */
  88. @Override
  89. @DataScope(deptAlias = "d", userAlias = "u")
  90. public List<SysUser> selectUnallocatedList(SysUser user)
  91. {
  92. return userMapper.selectUnallocatedList(user);
  93. }
  94. /**
  95. * 通过用户名查询用户
  96. *
  97. * @param userName 用户名
  98. * @return 用户对象信息
  99. */
  100. @Override
  101. public SysUser selectUserByUserName(String userName)
  102. {
  103. return userMapper.selectUserByUserName(userName);
  104. }
  105. /**
  106. * 通过用户ID查询用户
  107. *
  108. * @param userId 用户ID
  109. * @return 用户对象信息
  110. */
  111. @Override
  112. public SysUser selectUserById(Long userId)
  113. {
  114. return userMapper.selectUserById(userId);
  115. }
  116. /**
  117. * 查询用户所属角色组
  118. *
  119. * @param userName 用户名
  120. * @return 结果
  121. */
  122. @Override
  123. public String selectUserRoleGroup(String userName)
  124. {
  125. List<SysRole> list = roleMapper.selectRolesByUserName(userName);
  126. if (CollectionUtils.isEmpty(list))
  127. {
  128. return StringUtils.EMPTY;
  129. }
  130. return list.stream().map(SysRole::getRoleName).collect(Collectors.joining(","));
  131. }
  132. /**
  133. * 查询用户所属岗位组
  134. *
  135. * @param userName 用户名
  136. * @return 结果
  137. */
  138. @Override
  139. public String selectUserPostGroup(String userName)
  140. {
  141. List<SysPost> list = postMapper.selectPostsByUserName(userName);
  142. if (CollectionUtils.isEmpty(list))
  143. {
  144. return StringUtils.EMPTY;
  145. }
  146. return list.stream().map(SysPost::getPostName).collect(Collectors.joining(","));
  147. }
  148. /**
  149. * 校验用户名称是否唯一
  150. *
  151. * @param user 用户信息
  152. * @return 结果
  153. */
  154. @Override
  155. public boolean checkUserNameUnique(SysUser user)
  156. {
  157. Long userId = StringUtils.isNull(user.getUserId()) ? -1L : user.getUserId();
  158. SysUser info = userMapper.checkUserNameUnique(user.getUserName());
  159. if (StringUtils.isNotNull(info) && info.getUserId().longValue() != userId.longValue())
  160. {
  161. return UserConstants.NOT_UNIQUE;
  162. }
  163. return UserConstants.UNIQUE;
  164. }
  165. /**
  166. * 校验手机号码是否唯一
  167. *
  168. * @param user 用户信息
  169. * @return
  170. */
  171. @Override
  172. public boolean checkPhoneUnique(SysUser user)
  173. {
  174. Long userId = StringUtils.isNull(user.getUserId()) ? -1L : user.getUserId();
  175. SysUser info = userMapper.checkPhoneUnique(user.getPhonenumber());
  176. if (StringUtils.isNotNull(info) && info.getUserId().longValue() != userId.longValue())
  177. {
  178. return UserConstants.NOT_UNIQUE;
  179. }
  180. return UserConstants.UNIQUE;
  181. }
  182. /**
  183. * 校验email是否唯一
  184. *
  185. * @param user 用户信息
  186. * @return
  187. */
  188. @Override
  189. public boolean checkEmailUnique(SysUser user)
  190. {
  191. Long userId = StringUtils.isNull(user.getUserId()) ? -1L : user.getUserId();
  192. SysUser info = userMapper.checkEmailUnique(user.getEmail());
  193. if (StringUtils.isNotNull(info) && info.getUserId().longValue() != userId.longValue())
  194. {
  195. return UserConstants.NOT_UNIQUE;
  196. }
  197. return UserConstants.UNIQUE;
  198. }
  199. /**
  200. * 校验用户是否允许操作
  201. *
  202. * @param user 用户信息
  203. */
  204. @Override
  205. public void checkUserAllowed(SysUser user)
  206. {
  207. if (StringUtils.isNotNull(user.getUserId()) && user.isAdmin())
  208. {
  209. throw new ServiceException("不允许操作超级管理员用户");
  210. }
  211. }
  212. /**
  213. * 校验用户是否有数据权限
  214. *
  215. * @param userId 用户id
  216. */
  217. @Override
  218. public void checkUserDataScope(Long userId)
  219. {
  220. if (!SecurityUtils.isAdmin())
  221. {
  222. SysUser user = new SysUser();
  223. user.setUserId(userId);
  224. List<SysUser> users = SpringUtils.getAopProxy(this).selectUserList(user);
  225. if (StringUtils.isEmpty(users))
  226. {
  227. throw new ServiceException("没有权限访问用户数据!");
  228. }
  229. }
  230. }
  231. /**
  232. * 新增保存用户信息
  233. *
  234. * @param user 用户信息
  235. * @return 结果
  236. */
  237. @Override
  238. @Transactional
  239. public int insertUser(SysUser user)
  240. {
  241. // 新增用户信息
  242. int rows = userMapper.insertUser(user);
  243. // 新增用户岗位关联
  244. insertUserPost(user);
  245. // 新增用户与角色管理
  246. insertUserRole(user);
  247. return rows;
  248. }
  249. /**
  250. * 注册用户信息
  251. *
  252. * @param user 用户信息
  253. * @return 结果
  254. */
  255. @Override
  256. public boolean registerUser(SysUser user)
  257. {
  258. return userMapper.insertUser(user) > 0;
  259. }
  260. /**
  261. * 修改保存用户信息
  262. *
  263. * @param user 用户信息
  264. * @return 结果
  265. */
  266. @Override
  267. @Transactional
  268. public int updateUser(SysUser user)
  269. {
  270. Long userId = user.getUserId();
  271. // 删除用户与角色关联
  272. userRoleMapper.deleteUserRoleByUserId(userId);
  273. // 新增用户与角色管理
  274. insertUserRole(user);
  275. // 删除用户与岗位关联
  276. userPostMapper.deleteUserPostByUserId(userId);
  277. // 新增用户与岗位管理
  278. insertUserPost(user);
  279. return userMapper.updateUser(user);
  280. }
  281. /**
  282. * 用户授权角色
  283. *
  284. * @param userId 用户ID
  285. * @param roleIds 角色组
  286. */
  287. @Override
  288. @Transactional
  289. public void insertUserAuth(Long userId, Long[] roleIds)
  290. {
  291. userRoleMapper.deleteUserRoleByUserId(userId);
  292. insertUserRole(userId, roleIds);
  293. }
  294. /**
  295. * 修改用户状态
  296. *
  297. * @param user 用户信息
  298. * @return 结果
  299. */
  300. @Override
  301. public int updateUserStatus(SysUser user)
  302. {
  303. return userMapper.updateUserStatus(user.getUserId(), user.getStatus());
  304. }
  305. /**
  306. * 修改用户基本信息
  307. *
  308. * @param user 用户信息
  309. * @return 结果
  310. */
  311. @Override
  312. public int updateUserProfile(SysUser user)
  313. {
  314. return userMapper.updateUser(user);
  315. }
  316. /**
  317. * 修改用户头像
  318. *
  319. * @param userId 用户ID
  320. * @param avatar 头像地址
  321. * @return 结果
  322. */
  323. @Override
  324. public boolean updateUserAvatar(Long userId, String avatar)
  325. {
  326. return userMapper.updateUserAvatar(userId, avatar) > 0;
  327. }
  328. /**
  329. * 更新用户登录信息(IP和登录时间)
  330. *
  331. * @param userId 用户ID
  332. * @param loginIp 登录IP地址
  333. * @param loginDate 登录时间
  334. * @return 结果
  335. */
  336. public void updateLoginInfo(Long userId, String loginIp, Date loginDate)
  337. {
  338. userMapper.updateLoginInfo(userId, loginIp, loginDate);
  339. }
  340. /**
  341. * 重置用户密码
  342. *
  343. * @param user 用户信息
  344. * @return 结果
  345. */
  346. @Override
  347. public int resetPwd(SysUser user)
  348. {
  349. return userMapper.resetUserPwd(user.getUserId(), user.getPassword());
  350. }
  351. /**
  352. * 重置用户密码
  353. *
  354. * @param userId 用户ID
  355. * @param password 密码
  356. * @return 结果
  357. */
  358. @Override
  359. public int resetUserPwd(Long userId, String password)
  360. {
  361. return userMapper.resetUserPwd(userId, password);
  362. }
  363. /**
  364. * 新增用户角色信息
  365. *
  366. * @param user 用户对象
  367. */
  368. public void insertUserRole(SysUser user)
  369. {
  370. this.insertUserRole(user.getUserId(), user.getRoleIds());
  371. }
  372. /**
  373. * 新增用户岗位信息
  374. *
  375. * @param user 用户对象
  376. */
  377. public void insertUserPost(SysUser user)
  378. {
  379. Long[] posts = user.getPostIds();
  380. if (StringUtils.isNotEmpty(posts))
  381. {
  382. // 新增用户与岗位管理
  383. List<SysUserPost> list = new ArrayList<SysUserPost>(posts.length);
  384. for (Long postId : posts)
  385. {
  386. SysUserPost up = new SysUserPost();
  387. up.setUserId(user.getUserId());
  388. up.setPostId(postId);
  389. list.add(up);
  390. }
  391. userPostMapper.batchUserPost(list);
  392. }
  393. }
  394. /**
  395. * 新增用户角色信息
  396. *
  397. * @param userId 用户ID
  398. * @param roleIds 角色组
  399. */
  400. public void insertUserRole(Long userId, Long[] roleIds)
  401. {
  402. if (StringUtils.isNotEmpty(roleIds))
  403. {
  404. // 新增用户与角色管理
  405. List<SysUserRole> list = new ArrayList<SysUserRole>(roleIds.length);
  406. for (Long roleId : roleIds)
  407. {
  408. SysUserRole ur = new SysUserRole();
  409. ur.setUserId(userId);
  410. ur.setRoleId(roleId);
  411. list.add(ur);
  412. }
  413. userRoleMapper.batchUserRole(list);
  414. }
  415. }
  416. /**
  417. * 通过用户ID删除用户
  418. *
  419. * @param userId 用户ID
  420. * @return 结果
  421. */
  422. @Override
  423. @Transactional
  424. public int deleteUserById(Long userId)
  425. {
  426. // 删除用户与角色关联
  427. userRoleMapper.deleteUserRoleByUserId(userId);
  428. // 删除用户与岗位表
  429. userPostMapper.deleteUserPostByUserId(userId);
  430. return userMapper.deleteUserById(userId);
  431. }
  432. /**
  433. * 批量删除用户信息
  434. *
  435. * @param userIds 需要删除的用户ID
  436. * @return 结果
  437. */
  438. @Override
  439. @Transactional
  440. public int deleteUserByIds(Long[] userIds)
  441. {
  442. for (Long userId : userIds)
  443. {
  444. checkUserAllowed(new SysUser(userId));
  445. checkUserDataScope(userId);
  446. }
  447. // 删除用户与角色关联
  448. userRoleMapper.deleteUserRole(userIds);
  449. // 删除用户与岗位关联
  450. userPostMapper.deleteUserPost(userIds);
  451. return userMapper.deleteUserByIds(userIds);
  452. }
  453. /**
  454. * 导入用户数据
  455. *
  456. * @param userList 用户数据列表
  457. * @param isUpdateSupport 是否更新支持,如果已存在,则进行更新数据
  458. * @param operName 操作用户
  459. * @return 结果
  460. */
  461. @Override
  462. public String importUser(List<SysUser> userList, Boolean isUpdateSupport, String operName)
  463. {
  464. if (StringUtils.isNull(userList) || userList.size() == 0)
  465. {
  466. throw new ServiceException("导入用户数据不能为空!");
  467. }
  468. int successNum = 0;
  469. int failureNum = 0;
  470. StringBuilder successMsg = new StringBuilder();
  471. StringBuilder failureMsg = new StringBuilder();
  472. for (SysUser user : userList)
  473. {
  474. try
  475. {
  476. // 验证是否存在这个用户
  477. SysUser u = userMapper.selectUserByUserName(user.getUserName());
  478. if (StringUtils.isNull(u))
  479. {
  480. BeanValidators.validateWithException(validator, user);
  481. deptService.checkDeptDataScope(user.getDeptId());
  482. String password = configService.selectConfigByKey("sys.user.initPassword");
  483. user.setPassword(SecurityUtils.encryptPassword(password));
  484. user.setCreateBy(operName);
  485. userMapper.insertUser(user);
  486. successNum++;
  487. successMsg.append("<br/>" + successNum + "、账号 " + user.getUserName() + " 导入成功");
  488. }
  489. else if (isUpdateSupport)
  490. {
  491. BeanValidators.validateWithException(validator, user);
  492. checkUserAllowed(u);
  493. checkUserDataScope(u.getUserId());
  494. deptService.checkDeptDataScope(user.getDeptId());
  495. user.setUserId(u.getUserId());
  496. user.setDeptId(u.getDeptId());
  497. user.setUpdateBy(operName);
  498. userMapper.updateUser(user);
  499. successNum++;
  500. successMsg.append("<br/>" + successNum + "、账号 " + user.getUserName() + " 更新成功");
  501. }
  502. else
  503. {
  504. failureNum++;
  505. failureMsg.append("<br/>" + failureNum + "、账号 " + user.getUserName() + " 已存在");
  506. }
  507. }
  508. catch (Exception e)
  509. {
  510. failureNum++;
  511. String msg = "<br/>" + failureNum + "、账号 " + user.getUserName() + " 导入失败:";
  512. failureMsg.append(msg + e.getMessage());
  513. log.error(msg, e);
  514. }
  515. }
  516. if (failureNum > 0)
  517. {
  518. failureMsg.insert(0, "很抱歉,导入失败!共 " + failureNum + " 条数据格式不正确,错误如下:");
  519. throw new ServiceException(failureMsg.toString());
  520. }
  521. else
  522. {
  523. successMsg.insert(0, "恭喜您,数据已全部导入成功!共 " + successNum + " 条,数据如下:");
  524. }
  525. return successMsg.toString();
  526. }
  527. }