From fe7fa03c8f6047fe32c8477c0d3548d8f30e151d Mon Sep 17 00:00:00 2001
From: zhuo <2089219845@qq.com>
Date: 星期四, 13 三月 2025 14:01:36 +0800
Subject: [PATCH] Merge branch 'dev' into dev_dz

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java |   50 +++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 43 insertions(+), 7 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java
index c05ebf3..c620578 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java
@@ -2,13 +2,17 @@
 
 import java.util.List;
 import java.util.Set;
+import java.util.UUID;
+
+import com.ruoyi.common.annotation.Anonymous;
+import com.ruoyi.common.config.SsoBean;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.GetMapping;
 import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.RequestBody;
 import org.springframework.web.bind.annotation.RestController;
 import com.ruoyi.common.constant.Constants;
-import com.ruoyi.common.core.domain.Result;
+import com.ruoyi.common.core.domain.AjaxResult;
 import com.ruoyi.common.core.domain.entity.SysMenu;
 import com.ruoyi.common.core.domain.entity.SysUser;
 import com.ruoyi.common.core.domain.model.LoginBody;
@@ -39,6 +43,9 @@
     @Autowired
     private TokenService tokenService;
 
+    @Autowired
+    private SsoBean ssoBean;
+
     /**
      * 鐧诲綍鏂规硶
      *
@@ -46,9 +53,9 @@
      * @return 缁撴灉
      */
     @PostMapping("/login")
-    public Result login(@RequestBody LoginBody loginBody)
+    public AjaxResult login(@RequestBody LoginBody loginBody)
     {
-        Result ajax = Result.success();
+        AjaxResult ajax = AjaxResult.success();
         // 鐢熸垚浠ょ墝
         String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
                 loginBody.getUuid());
@@ -62,7 +69,7 @@
      * @return 鐢ㄦ埛淇℃伅
      */
     @GetMapping("getInfo")
-    public Result getInfo()
+    public AjaxResult getInfo()
     {
         LoginUser loginUser = SecurityUtils.getLoginUser();
         SysUser user = loginUser.getUser();
@@ -75,7 +82,7 @@
             loginUser.setPermissions(permissions);
             tokenService.refreshToken(loginUser);
         }
-        Result ajax = Result.success();
+        AjaxResult ajax = AjaxResult.success();
         ajax.put("user", user);
         ajax.put("roles", roles);
         ajax.put("permissions", permissions);
@@ -88,10 +95,39 @@
      * @return 璺敱淇℃伅
      */
     @GetMapping("getRouters")
-    public Result getRouters()
+    public AjaxResult getRouters()
     {
         Long userId = SecurityUtils.getUserId();
         List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId);
-        return Result.success(menuService.buildMenus(menus));
+        return AjaxResult.success(menuService.buildMenus(menus));
+    }
+
+    /**
+     * 鑾峰彇缁熶竴鐧诲綍骞冲彴鑾峰彇CODE鍦板潃
+     *
+     * @return
+     */
+
+    @Anonymous
+    @GetMapping("/getSsoAuthUrl")
+    public AjaxResult getSsoAuthUrl() {
+        String uuid = UUID.randomUUID().toString();
+        return AjaxResult.success(ssoBean.getUrl() + "/oauth2/auth?response_type=code&scope=openid&client_id=" + ssoBean.getClientId() + "&redirect_uri=" + ssoBean.getCallbackUrl() + "&state=" + uuid);
+    }
+
+    /**
+     * 鍗曠偣鐧诲綍
+     *
+     * @param code 鐧诲綍淇℃伅
+     * @return 缁撴灉
+     */
+    @PostMapping("/loginBySSO")
+    public AjaxResult loginBySSO(String code)
+    {
+        AjaxResult ajax = AjaxResult.success();
+        // 鐢熸垚浠ょ墝
+        String token = loginService.loginBySSO(code);
+        ajax.put(Constants.TOKEN, token);
+        return ajax;
     }
 }

--
Gitblit v1.9.3