From fc5d43e590ac5453f1e1f96fcf84f558f383ca40 Mon Sep 17 00:00:00 2001
From: baoshiwei <baoshiwei@shlanbao.cn>
Date: 星期五, 21 三月 2025 14:18:21 +0800
Subject: [PATCH] feat(social): 添加 Keycloak单点登录功能

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

diff --git a/eims/ruoyi-admin/src/main/java/org/dromara/web/service/impl/SocialAuthStrategy.java b/eims/ruoyi-admin/src/main/java/org/dromara/web/service/impl/SocialAuthStrategy.java
index 8463026..ef2caf8 100644
--- a/eims/ruoyi-admin/src/main/java/org/dromara/web/service/impl/SocialAuthStrategy.java
+++ b/eims/ruoyi-admin/src/main/java/org/dromara/web/service/impl/SocialAuthStrategy.java
@@ -7,6 +7,7 @@
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.http.HttpUtil;
 import cn.hutool.http.Method;
+import com.aizuda.snailjob.common.core.constant.SystemConstants;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import me.zhyd.oauth.model.AuthResponse;
@@ -23,6 +24,8 @@
 import org.dromara.common.social.config.properties.SocialProperties;
 import org.dromara.common.social.utils.SocialUtils;
 import org.dromara.common.tenant.helper.TenantHelper;
+import org.dromara.system.domain.SysUser;
+import org.dromara.system.domain.bo.SysSocialBo;
 import org.dromara.system.domain.vo.SysClientVo;
 import org.dromara.system.domain.vo.SysSocialVo;
 import org.dromara.system.domain.vo.SysUserVo;
@@ -77,6 +80,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("0");
+
+                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)) {

--
Gitblit v1.9.3