From eafecc3ac0227960f2b8fa377be27f066e10e50f Mon Sep 17 00:00:00 2001
From: baoshiwei <baoshiwei@shlanbao.cn>
Date: 星期二, 20 五月 2025 10:47:58 +0800
Subject: [PATCH] perf(lb-qms): 优化查询功能和时间范围筛选

---
 ruoyi-admin/src/main/java/org/dromara/web/service/impl/SocialAuthStrategy.java |  116 +++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 91 insertions(+), 25 deletions(-)

diff --git a/ruoyi-admin/src/main/java/org/dromara/web/service/impl/SocialAuthStrategy.java b/ruoyi-admin/src/main/java/org/dromara/web/service/impl/SocialAuthStrategy.java
index 01db200..9d62dd8 100644
--- a/ruoyi-admin/src/main/java/org/dromara/web/service/impl/SocialAuthStrategy.java
+++ b/ruoyi-admin/src/main/java/org/dromara/web/service/impl/SocialAuthStrategy.java
@@ -10,10 +10,12 @@
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import me.zhyd.oauth.model.AuthResponse;
+import me.zhyd.oauth.model.AuthToken;
 import me.zhyd.oauth.model.AuthUser;
+import org.dromara.common.core.constant.SystemConstants;
 import org.dromara.common.core.domain.model.LoginUser;
+import org.dromara.common.core.domain.model.PasswordLoginBody;
 import org.dromara.common.core.domain.model.SocialLoginBody;
-import org.dromara.common.core.enums.UserStatus;
 import org.dromara.common.core.exception.ServiceException;
 import org.dromara.common.core.exception.user.UserException;
 import org.dromara.common.core.utils.StreamUtils;
@@ -21,8 +23,13 @@
 import org.dromara.common.json.utils.JsonUtils;
 import org.dromara.common.satoken.utils.LoginHelper;
 import org.dromara.common.social.config.properties.SocialProperties;
+import org.dromara.common.social.keycloak.AuthKeycloakRequest;
 import org.dromara.common.social.utils.SocialUtils;
 import org.dromara.common.tenant.helper.TenantHelper;
+import org.dromara.system.domain.SysSocial;
+import org.dromara.system.domain.SysUser;
+import org.dromara.system.domain.bo.SysSocialBo;
+import org.dromara.system.domain.bo.SysUserBo;
 import org.dromara.system.domain.vo.SysClientVo;
 import org.dromara.system.domain.vo.SysSocialVo;
 import org.dromara.system.domain.vo.SysUserVo;
@@ -59,15 +66,34 @@
      */
     @Override
     public LoginVo login(String body, SysClientVo client) {
-        SocialLoginBody loginBody = JsonUtils.parseObject(body, SocialLoginBody.class);
-        ValidatorUtils.validate(loginBody);
-        AuthResponse<AuthUser> response = SocialUtils.loginAuth(
+        // 濡傛灉bodyp瀛楃涓蹭腑鍖呭惈login_type瀛楁锛屽垯灏哹ody杞负password鐧诲綍
+        AuthUser authUserData = null;
+        String tenantId = null;
+        if (body.contains("login_type")) {
+            PasswordLoginBody passwordLoginBody = JsonUtils.parseObject(body, PasswordLoginBody.class);
+            tenantId = passwordLoginBody.getTenantId();
+            ValidatorUtils.validate(passwordLoginBody);
+            AuthKeycloakRequest authRequest = SocialUtils.getAuthKeyloakRequest("keycloak", socialProperties);
+            AuthToken accessToken = authRequest.getAccessToken(passwordLoginBody);
+            authUserData = authRequest.getUserInfo(accessToken);
+
+
+        } else {
+            SocialLoginBody loginBody = JsonUtils.parseObject(body, SocialLoginBody.class);
+            tenantId =loginBody.getTenantId();
+                ValidatorUtils.validate(loginBody);
+            AuthResponse<AuthUser> response = SocialUtils.loginAuth(
                 loginBody.getSource(), loginBody.getSocialCode(),
                 loginBody.getSocialState(), socialProperties);
-        if (!response.ok()) {
-            throw new ServiceException(response.getMsg());
+            if (!response.ok()) {
+                throw new ServiceException(response.getMsg());
+            }
+            authUserData = response.getData();
         }
-        AuthUser authUserData = response.getData();
+
+
+
+
         if ("GITEE".equals(authUserData.getSource())) {
             // 濡傜敤鎴蜂娇鐢� gitee 鐧诲綍椤烘墜 star 缁欎綔鑰呬竴鐐规敮鎸� 鎷掔粷鐧藉珫
             HttpUtil.createRequest(Method.PUT, "https://gitee.com/api/v5/user/starred/dromara/RuoYi-Vue-Plus")
@@ -77,6 +103,47 @@
                     .formStr(MapUtil.of("access_token", authUserData.getToken().getAccessToken()))
                     .executeAsync();
         }
+        if ("KEYCLOAK".equals(authUserData.getSource())) {
+            // 鏂板KEYCLOAK鐢ㄦ埛鑷姩鍒涘缓閫昏緫
+            String authId = authUserData.getSource() + authUserData.getUuid();
+            List<SysSocialVo> list = sysSocialService.selectByAuthId(authId);
+            if (CollUtil.isEmpty(list)) {
+                // 鑷姩鍒涘缓鏂扮敤鎴�
+                SysUser newUser = new SysUser();
+                newUser.setUserName(authUserData.getUsername());
+                newUser.setEmail(authUserData.getEmail());
+                newUser.setNickName(authUserData.getNickname());
+                newUser.setPassword("Initial123@"); // 鍒濆瀵嗙爜闇�绗﹀悎瀹夊叏绛栫暐
+                newUser.setStatus(SystemConstants.NORMAL);
+
+                userMapper.insert(newUser); // 鍋囪瀛樺湪鎻掑叆鏂规硶
+
+                // 鍒涘缓绀句氦缁戝畾璁板綍
+                SysSocialBo newSocial = new SysSocialBo();
+                newSocial.setUserId(newUser.getUserId());
+                newSocial.setUserName(newUser.getUserName());
+                newSocial.setAuthId(authId);
+                newSocial.setSource(authUserData.getSource());
+                newSocial.setTenantId(newUser.getTenantId());
+                newSocial.setOpenId(authUserData.getUuid());
+                newSocial.setAccessToken(authUserData.getToken().getAccessToken());
+                newSocial.setRefreshToken(authUserData.getToken().getRefreshToken());
+                newSocial.setIdToken(authUserData.getToken().getIdToken());
+                sysSocialService.insertByBo(newSocial); // 闇�纭繚鏈嶅姟鏈夋柊澧炴柟娉�
+
+                // 閲嶆柊鏌ヨ纭繚鏁版嵁鍙敤
+                list = sysSocialService.selectByAuthId(authId);
+            } else {
+                // 鏇存柊绀句氦缁戝畾璁板綍
+                SysSocialBo socialBo = new SysSocialBo();
+                socialBo.setId(list.get(0).getId());
+                socialBo.setAccessToken(authUserData.getToken().getAccessToken());
+                socialBo.setRefreshToken(authUserData.getToken().getRefreshToken());
+                socialBo.setIdToken(authUserData.getToken().getIdToken());
+                sysSocialService.updateByBo(socialBo);
+
+            }
+        }
 
         List<SysSocialVo> list = sysSocialService.selectByAuthId(authUserData.getSource() + authUserData.getUuid());
         if (CollUtil.isEmpty(list)) {
@@ -84,7 +151,8 @@
         }
         SysSocialVo social;
         if (TenantHelper.isEnable()) {
-            Optional<SysSocialVo> opt = StreamUtils.findAny(list, x -> x.getTenantId().equals(loginBody.getTenantId()));
+            String finalTenantId = tenantId;
+            Optional<SysSocialVo> opt = StreamUtils.findAny(list, x -> x.getTenantId().equals(finalTenantId));
             if (opt.isEmpty()) {
                 throw new ServiceException("瀵逛笉璧凤紝浣犳病鏈夋潈闄愮櫥褰曞綋鍓嶇鎴凤紒");
             }
@@ -92,11 +160,11 @@
         } else {
             social = list.get(0);
         }
-        // 鏌ユ壘鐢ㄦ埛
-        SysUserVo user = loadUser(social.getTenantId(), social.getUserId());
-
-        // 姝ゅ鍙牴鎹櫥褰曠敤鎴风殑鏁版嵁涓嶅悓 鑷鍒涘缓 loginUser 灞炴�т笉澶熺敤缁ф壙鎵╁睍灏辫浜�
-        LoginUser loginUser = loginService.buildLoginUser(user);
+        LoginUser loginUser = TenantHelper.dynamic(social.getTenantId(), () -> {
+            SysUserVo user = loadUser(social.getUserId());
+            // 姝ゅ鍙牴鎹櫥褰曠敤鎴风殑鏁版嵁涓嶅悓 鑷鍒涘缓 loginUser 灞炴�т笉澶熺敤缁ф壙鎵╁睍灏辫浜�
+            return loginService.buildLoginUser(user);
+        });
         loginUser.setClientKey(client.getClientKey());
         loginUser.setDeviceType(client.getDeviceType());
         SaLoginModel model = new SaLoginModel();
@@ -116,18 +184,16 @@
         return loginVo;
     }
 
-    private SysUserVo loadUser(String tenantId, Long userId) {
-        return TenantHelper.dynamic(tenantId, () -> {
-            SysUserVo user = userMapper.selectVoById(userId);
-            if (ObjectUtil.isNull(user)) {
-                log.info("鐧诲綍鐢ㄦ埛锛歿} 涓嶅瓨鍦�.", "");
-                throw new UserException("user.not.exists", "");
-            } else if (UserStatus.DISABLE.getCode().equals(user.getStatus())) {
-                log.info("鐧诲綍鐢ㄦ埛锛歿} 宸茶鍋滅敤.", "");
-                throw new UserException("user.blocked", "");
-            }
-            return user;
-        });
+    private SysUserVo loadUser(Long userId) {
+        SysUserVo user = userMapper.selectVoById(userId);
+        if (ObjectUtil.isNull(user)) {
+            log.info("鐧诲綍鐢ㄦ埛锛歿} 涓嶅瓨鍦�.", "");
+            throw new UserException("user.not.exists", "");
+        } else if (SystemConstants.DISABLE.equals(user.getStatus())) {
+            log.info("鐧诲綍鐢ㄦ埛锛歿} 宸茶鍋滅敤.", "");
+            throw new UserException("user.blocked", "");
+        }
+        return user;
     }
 
 }

--
Gitblit v1.9.3