AdminUserServiceImpl.java 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. package com.kym.service.impl;
  2. import cn.dev33.satoken.stp.StpUtil;
  3. import cn.hutool.core.bean.BeanUtil;
  4. import cn.hutool.crypto.asymmetric.KeyType;
  5. import cn.hutool.crypto.asymmetric.RSA;
  6. import cn.hutool.crypto.digest.DigestAlgorithm;
  7. import cn.hutool.crypto.digest.Digester;
  8. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  9. import com.github.pagehelper.PageHelper;
  10. import com.github.yulichang.toolkit.JoinWrappers;
  11. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  12. import com.kym.common.R;
  13. import com.kym.common.constant.ResponseEnum;
  14. import com.kym.common.exception.BusinessException;
  15. import com.kym.common.utils.CommUtil;
  16. import com.kym.common.utils.IDGenerator;
  17. import com.kym.entity.AdminUser;
  18. import com.kym.entity.AdminUserRole;
  19. import com.kym.entity.InvestorInfo;
  20. import com.kym.entity.Role;
  21. import com.kym.entity.common.PageBean;
  22. import com.kym.entity.queryParams.CommonQueryParam;
  23. import com.kym.entity.vo.AdminUserVo;
  24. import com.kym.mapper.AdminUserMapper;
  25. import com.kym.service.AdminUserRoleService;
  26. import com.kym.service.AdminUserService;
  27. import com.kym.service.InvestorInfoService;
  28. import com.kym.service.RoleService;
  29. import com.kym.service.mybatisplus.MyBaseServiceImpl;
  30. import jakarta.annotation.Resource;
  31. import org.slf4j.Logger;
  32. import org.slf4j.LoggerFactory;
  33. import org.springframework.beans.BeanUtils;
  34. import org.springframework.beans.factory.annotation.Value;
  35. import org.springframework.stereotype.Service;
  36. import org.springframework.transaction.annotation.Transactional;
  37. import java.nio.charset.StandardCharsets;
  38. import java.time.LocalDateTime;
  39. import java.util.Collections;
  40. import java.util.List;
  41. import java.util.Map;
  42. /**
  43. * <p>
  44. * 用户表 服务实现类
  45. * </p>
  46. *
  47. * @author skyline
  48. * @since 2023-07-11
  49. */
  50. @Service
  51. public class AdminUserServiceImpl extends MyBaseServiceImpl<AdminUserMapper, AdminUser> implements AdminUserService {
  52. final static Digester MD5 = new Digester(DigestAlgorithm.MD5);
  53. private static final Logger LOGGER = LoggerFactory.getLogger(AdminUserServiceImpl.class);
  54. private final InvestorInfoService investorInfoService;
  55. private final RoleService roleService;
  56. @Value("${password.privateKey}")
  57. private String privateKey;
  58. @Value("${password.publicKey}")
  59. private String publicKey;
  60. @Resource
  61. private AdminUserRoleService adminUserRoleService;
  62. public AdminUserServiceImpl(InvestorInfoService investorInfoService, RoleService roleService) {
  63. this.investorInfoService = investorInfoService;
  64. this.roleService = roleService;
  65. }
  66. /**
  67. * 获取投资者角色对应的adminUser用户
  68. */
  69. @Override
  70. public List<AdminUser> getInvestorAdminUsers() {
  71. // 投资者角色ID
  72. var investorRole = roleService.lambdaQuery()
  73. .eq(Role::getRoleName, "投资者")
  74. .eq(Role::getRoleDesc, "investor").one();
  75. // 查找所有角色为investor的adminUser用户
  76. MPJLambdaWrapper<AdminUser> wrapper = JoinWrappers.lambda(AdminUser.class)
  77. .selectAll(AdminUser.class)
  78. .leftJoin(AdminUserRole.class, AdminUserRole::getAdminUserId, AdminUser::getId)
  79. .eq(AdminUserRole::getRoleId, investorRole.getId());
  80. return this.selectJoinList(AdminUser.class, wrapper);
  81. }
  82. @Override
  83. public R<?> login(String mobilePhone, String password) {
  84. var user = lambdaQuery().eq(AdminUser::getMobilePhone, mobilePhone).one();
  85. if (user.getStatus() == AdminUser.STATUS_禁用) {
  86. throw new BusinessException("用户状态异常,无法登录");
  87. }
  88. RSA rsa = new RSA(privateKey, publicKey);
  89. password = rsa.decryptStr(password, KeyType.PrivateKey, StandardCharsets.UTF_8);
  90. var pwd = MD5.digestHex(password.concat(MD5.digestHex(mobilePhone).substring(0, 5)));
  91. if (pwd.equals(user.getPassword())) {
  92. StpUtil.login(user.getId());
  93. // 用户名存入session,统一日志读取使用
  94. StpUtil.getSession().set("mobilePhone", user.getMobilePhone());
  95. StpUtil.getSession().set("username", user.getUsername());
  96. user.setLastLoginTime(LocalDateTime.now());
  97. this.updateById(user);
  98. LOGGER.info("操作员:" + mobilePhone + "/id:" + user.getId() + "登录");
  99. // token在cookie中有隐式返回,这里多做显式返回
  100. return R.success(Map.of("id", user.getId(), "accessToken", StpUtil.getTokenValue()));
  101. }
  102. return R.failed(ResponseEnum.LOGIN_FAILED);
  103. }
  104. @Override
  105. public void logout(Long id) {
  106. StpUtil.logout(id);
  107. }
  108. /**
  109. * 用户信息、权限、角色
  110. *
  111. * @return
  112. */
  113. @Override
  114. public Object profile() {
  115. long userId = StpUtil.getLoginIdAsLong();
  116. return listUserPermissions(userId);
  117. }
  118. @Override
  119. public List<AdminUserVo> listUserPermissions(Long loginId) {
  120. return baseMapper.listUserPermissions(loginId);
  121. }
  122. @Override
  123. public PageBean<AdminUserVo> listAdminUser(CommonQueryParam params) {
  124. PageHelper.startPage(params.getPageNum(), params.getPageSize());
  125. var list = baseMapper.listAdminUser(params);
  126. return new PageBean<>(list);
  127. }
  128. @Override
  129. public String createAdminUser(AdminUserVo adminUserVo) {
  130. var password = MD5.digestHex(adminUserVo.getPassword().concat(MD5.digestHex(adminUserVo.getMobilePhone()).substring(0, 5)));
  131. // 用户
  132. var adminUser = new AdminUser();
  133. BeanUtils.copyProperties(adminUserVo, adminUser);
  134. adminUser.setId(IDGenerator.INS().nextId());
  135. adminUser.setPassword(password);
  136. adminUser.setCreateTime(LocalDateTime.now());
  137. save(adminUser);
  138. // 角色和权限
  139. var adminUserRole = new AdminUserRole()
  140. .setAdminUserId(adminUser.getId())
  141. .setRoleId(adminUserVo.getRoleId());
  142. adminUserRoleService.save(adminUserRole);
  143. return String.valueOf(adminUser.getId());
  144. }
  145. @Override
  146. public Object detail(long id) {
  147. AdminUser adminUser = baseMapper.selectById(id);
  148. adminUser.setPassword(null);
  149. List<AdminUserRole> userRoleList = adminUserRoleService.lambdaQuery().eq(AdminUserRole::getAdminUserId, id).list();
  150. return Map.of("adminUser", adminUser, "roles", userRoleList);
  151. }
  152. @Transactional(rollbackFor = Exception.class)
  153. @Override
  154. public void updateRole(long userId, List<Long> roleIdList) {
  155. QueryWrapper wrapper = new QueryWrapper();
  156. wrapper.eq("admin_user_id", userId);
  157. adminUserRoleService.remove(wrapper);
  158. if (CommUtil.isEmptyOrNull(roleIdList)) {
  159. return;
  160. }
  161. roleIdList.forEach(roleId -> {
  162. AdminUserRole roleEntity = new AdminUserRole();
  163. roleEntity.setAdminUserId(userId);
  164. roleEntity.setRoleId(roleId);
  165. roleEntity.setCreateTime(LocalDateTime.now());
  166. roleEntity.setUpdateTime(LocalDateTime.now());
  167. adminUserRoleService.save(roleEntity);
  168. });
  169. }
  170. @Override
  171. @Transactional
  172. public void updateAdminUser(AdminUserVo adminUserVo) {
  173. AdminUser adminUser = new AdminUser();
  174. if (adminUserVo.getStatus() == AdminUser.STATUS_禁用) {
  175. adminUser.setStatus(AdminUser.STATUS_禁用);
  176. investorInfoService.lambdaUpdate().set(InvestorInfo::getStatus, InvestorInfo.STATUS_无效).eq(InvestorInfo::getAdminUserId, adminUserVo.getId()).update();
  177. } else {
  178. adminUser.setStatus(AdminUser.STATUS_启用);
  179. investorInfoService.lambdaUpdate().set(InvestorInfo::getStatus, InvestorInfo.STATUS_有效).eq(InvestorInfo::getAdminUserId, adminUserVo.getId()).update();
  180. }
  181. BeanUtil.copyProperties(adminUserVo, adminUser);
  182. baseMapper.updateById(adminUser);
  183. }
  184. @Override
  185. public PageBean<?> listUser(CommonQueryParam params) {
  186. PageHelper.startPage(params.getPageNum(), params.getPageSize());
  187. List<AdminUser> list = lambdaQuery()
  188. .like(!CommUtil.isEmptyOrNull(params.getUsername()), AdminUser::getUsername, params.getUsername())
  189. .like(!CommUtil.isEmptyOrNull(params.getMobilePhone()), AdminUser::getMobilePhone, params.getMobilePhone())
  190. .like(params.getStatus() != null, AdminUser::getStatus, params.getStatus())
  191. .list();
  192. return new PageBean<>(list);
  193. }
  194. @Override
  195. public Object wxLogin(AdminUser user) {
  196. CommUtil.asserts(CommUtil.isNotEmptyAndNull(user.getOpenId()), "微信账户信息错误");
  197. var adminUser = lambdaQuery()
  198. .eq(AdminUser::getOpenId, user.getOpenId())
  199. .eq(AdminUser::getMobilePhone, user.getMobilePhone())
  200. .eq(AdminUser::getStatus, AdminUser.STATUS_启用).one();
  201. if (null == adminUser) {
  202. //判断是否已有手机账号存在,有则自动绑定union id,无则创建账号
  203. adminUser = lambdaQuery()
  204. .eq(AdminUser::getMobilePhone, user.getMobilePhone())
  205. .eq(AdminUser::getStatus, AdminUser.STATUS_启用).one();
  206. if (null != adminUser) {
  207. adminUser.setOpenId(user.getOpenId());
  208. } else {
  209. //自动注册
  210. CommUtil.asserts(CommUtil.isNotEmptyAndNull(user.getMobilePhone()), "手机号不能为空");
  211. adminUser = new AdminUser();
  212. adminUser.setId(IDGenerator.INS().nextId());
  213. adminUser.setOpenId(user.getOpenId());
  214. adminUser.setStatus(AdminUser.STATUS_启用);
  215. adminUser.setMobilePhone(user.getMobilePhone());
  216. adminUser.setUsername(user.getMobilePhone());
  217. adminUser.setLastLoginTime(LocalDateTime.now());
  218. adminUser.setUpdateTime(LocalDateTime.now());
  219. this.save(adminUser);
  220. }
  221. }
  222. StpUtil.login(adminUser.getId());
  223. // 用户名存入session,统一日志读取使用
  224. StpUtil.getSession().set("mobilePhone", adminUser.getMobilePhone());
  225. StpUtil.getSession().set("username", adminUser.getUsername());
  226. adminUser.setLastLoginTime(LocalDateTime.now());
  227. adminUser.setMobilePhone(adminUser.getMobilePhone());
  228. this.updateById(adminUser);
  229. LOGGER.info("微信用户union:{},name:{},phone:{},id:{}登录", adminUser.getOpenId(), adminUser.getUsername(), adminUser.getMobilePhone(), adminUser.getId());
  230. // token在cookie中有隐式返回,这里多做显式返回
  231. adminUser.setPassword(null);
  232. adminUser.setOpenId(null);
  233. return Map.of("user", adminUser, "satoken", StpUtil.getTokenValue());
  234. }
  235. @Override
  236. public Object loginByOpenId(AdminUser user) {
  237. CommUtil.asserts(CommUtil.isNotEmptyAndNull(user.getOpenId()), "微信账户信息错误");
  238. var adminUser = lambdaQuery()
  239. .eq(AdminUser::getOpenId, user.getOpenId())
  240. .eq(AdminUser::getStatus, AdminUser.STATUS_启用).one();
  241. if (null == adminUser) {
  242. return Collections.emptyMap();
  243. } else {
  244. StpUtil.login(adminUser.getId());
  245. // 用户名存入session,统一日志读取使用
  246. StpUtil.getSession().set("mobilePhone", adminUser.getMobilePhone());
  247. StpUtil.getSession().set("username", adminUser.getUsername());
  248. adminUser.setLastLoginTime(LocalDateTime.now());
  249. this.updateById(adminUser);
  250. adminUser.setPassword(null);
  251. adminUser.setOpenId(null);
  252. return Map.of("user", adminUser, "satoken", StpUtil.getTokenValue());
  253. }
  254. }
  255. }