From 7ece553fd95f30dcfafa66f667ef9d0c064a22e6 Mon Sep 17 00:00:00 2001
From: xin <1099200748@qq.com>
Date: Sat, 19 Jul 2025 16:27:12 +0800
Subject: [PATCH] Merge branch 'pxb' into xin

---
 oying-system/src/main/java/com/oying/modules/system/service/impl/UserServiceImpl.java |   55 +++++++++++++++++++++++++++++++++----------------------
 1 files changed, 33 insertions(+), 22 deletions(-)

diff --git a/oying-system/src/main/java/com/oying/modules/system/service/impl/UserServiceImpl.java b/oying-system/src/main/java/com/oying/modules/system/service/impl/UserServiceImpl.java
index d6ce91d..ab437e5 100644
--- a/oying-system/src/main/java/com/oying/modules/system/service/impl/UserServiceImpl.java
+++ b/oying-system/src/main/java/com/oying/modules/system/service/impl/UserServiceImpl.java
@@ -5,7 +5,6 @@
 import com.oying.domain.BucketStorage;
 import com.oying.modules.security.service.OnlineUserService;
 import com.oying.modules.security.service.UserCacheManager;
-import com.oying.modules.system.domain.Job;
 import com.oying.modules.system.domain.Role;
 import com.oying.modules.system.domain.User;
 import com.oying.modules.system.domain.dto.UserQueryCriteria;
@@ -21,6 +20,7 @@
 import com.oying.exception.EntityExistException;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
+import org.springframework.util.ObjectUtils;
 import org.springframework.web.multipart.MultipartFile;
 
 import javax.servlet.http.HttpServletResponse;
@@ -81,12 +81,10 @@
 //        if (userMapper.findByEmail(resources.getEmail()) != null) {
 //            throw new EntityExistException(User.class, "email", resources.getEmail());
 //        }
-//        if (userMapper.findByPhone(resources.getPhone()) != null) {
-//            throw new EntityExistException(User.class, "phone", resources.getPhone());
-//        }
+        if (userMapper.findByPhone(resources.getPhone()) != null) {
+            throw new EntityExistException(User.class, "phone", resources.getPhone());
+        }
         save(resources);
-        // 保存用户岗位
-        userJobMapper.insertData(resources.getId(), resources.getJobs());
         // 保存用户角色
         userRoleMapper.insertData(resources.getId(), resources.getRoles());
     }
@@ -96,17 +94,20 @@
     public void update(User resources) throws Exception {
         User user = getById(resources.getId());
         User user1 = userMapper.findByUsername(resources.getUsername());
-//        User user2 = userMapper.findByEmail(resources.getEmail());
-//        User user3 = userMapper.findByPhone(resources.getPhone());
+        User user3 = userMapper.findByPhone(resources.getPhone());
         if (user1 != null && !user.getId().equals(user1.getId())) {
             throw new EntityExistException(User.class, "username", resources.getUsername());
         }
-//        if (user2 != null && !user.getId().equals(user2.getId())) {
-//            throw new EntityExistException(User.class, "email", resources.getEmail());
-//        }
-//        if (user3 != null && !user.getId().equals(user3.getId())) {
-//            throw new EntityExistException(User.class, "phone", resources.getPhone());
-//        }
+        if (user3 != null && !user.getId().equals(user3.getId())) {
+            throw new EntityExistException(User.class, "phone", resources.getPhone());
+        }
+        if (resources.getEmail() != null) {
+            User user2 = userMapper.findByEmail(resources.getEmail());
+            if (user2 != null && !user.getId().equals(user2.getId())) {
+                throw new EntityExistException(User.class, "email", resources.getEmail());
+            }
+            user.setEmail(resources.getEmail());
+        }
         // 如果用户的角色改变
         if (!resources.getRoles().equals(user.getRoles())) {
             redisUtils.del(CacheKey.DATA_USER + resources.getId());
@@ -119,22 +120,19 @@
             onlineUserService.kickOutForUsername(resources.getUsername());
         }
         user.setUsername(resources.getUsername());
-        user.setEmail(resources.getEmail());
         user.setEnabled(resources.getEnabled());
         user.setRoles(resources.getRoles());
-        user.setJobs(resources.getJobs());
         user.setPhone(resources.getPhone());
         user.setNickName(resources.getNickName());
         user.setGender(resources.getGender());
         saveOrUpdate(user);
         // 清除缓存
         delCaches(user.getId(), user.getUsername());
-        // 更新用户岗位
-        userJobMapper.deleteByUserId(resources.getId());
-        userJobMapper.insertData(resources.getId(), resources.getJobs());
         // 更新用户角色
-        userRoleMapper.deleteByUserId(resources.getId());
-        userRoleMapper.insertData(resources.getId(), resources.getRoles());
+        if (!ObjectUtils.isEmpty(resources.getRoles())) {
+            userRoleMapper.deleteByUserId(resources.getId());
+            userRoleMapper.insertData(resources.getId(), resources.getRoles());
+        }
     }
 
     @Override
@@ -179,6 +177,11 @@
     }
 
     @Override
+    public User findByRiderOpenId(String riderOpenId) {
+        return userMapper.findByRiderOpenId(riderOpenId);
+    }
+
+    @Override
     public User getLoginData(String userName) {
         return userMapper.findByUsername(userName);
     }
@@ -203,6 +206,14 @@
         });
         // 重置密码
         userMapper.resetPwd(ids, pwd);
+    }
+
+    @Override
+    public void updateRiderOpenId(User user1) {
+        User user = new User();
+        user.setId(user1.getId());
+        user.setRiderOpenId(user1.getRiderOpenId());
+        userMapper.updateById(user);
     }
 
     @Override
@@ -247,10 +258,10 @@
             Map<String, Object> map = new LinkedHashMap<>();
             map.put("用户名", user.getUsername());
             map.put("角色", roles);
-            map.put("岗位", user.getJobs().stream().map(Job::getName).collect(Collectors.toList()));
             map.put("邮箱", user.getEmail());
             map.put("状态", user.getEnabled() ? "启用" : "禁用");
             map.put("手机号码", user.getPhone());
+            map.put("openid", user.getOpenid());
             map.put("修改密码的时间", user.getPwdResetTime());
             map.put("创建日期", user.getCreateTime());
             list.add(map);

--
Gitblit v1.9.3