SysUserServiceImpl.java 16 KB

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