From a791022ff1311e1fb76930c398d6ff91036d0456 Mon Sep 17 00:00:00 2001
From: zhaoqingang <zhaoqg0118@163.com>
Date: 星期三, 11 十二月 2024 17:57:52 +0800
Subject: [PATCH] 新增加标签功能

---
 app/service/service_token.py |   57 ++++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 50 insertions(+), 7 deletions(-)

diff --git a/app/service/service_token.py b/app/service/service_token.py
index 9c54fed..215353b 100644
--- a/app/service/service_token.py
+++ b/app/service/service_token.py
@@ -1,15 +1,58 @@
+from Log import logger
+from app.config.config import settings
+from app.config.const import BISHENG, RAGFLOW
+from app.models import UserModel
 from app.models.token_model import TokenModel
+from app.service.auth import UserAppDao
+from app.service.bisheng import BishengService
+from app.service.ragflow import RagflowService
 
 
-def get_bisheng_token(db, user_id: int):
-    token = db.query(TokenModel).filter(TokenModel.user_id == user_id).first()
+async def get_bisheng_token(db, user_id: int):
+    token = await UserAppDao(db).get_data_by_id(user_id, BISHENG)
     if not token:
-        return None
+        token = db.query(TokenModel).filter(TokenModel.user_id == user_id).first()
+        if not token:
+            return None
+    else:
+        return token.access_token
     return token.bisheng_token
 
-
-def get_ragflow_token(db, user_id: int):
-    token = db.query(TokenModel).filter(TokenModel.user_id == user_id).first()
+async def get_ragflow_token(db, user_id: int):
+    token = await UserAppDao(db).get_data_by_id(user_id, RAGFLOW)
     if not token:
-        return None
+        token = db.query(TokenModel).filter(TokenModel.user_id == user_id).first()
+        if not token:
+            return None
+    else:
+        return token.access_token
     return token.ragflow_token
+
+async def get_ragflow_new_token(db, user_id: int, app_type):
+    user = db.query(UserModel).filter(UserModel.id == user_id).first()
+    if not user:
+        return None
+    if app_type == 1:
+        ragflow_service = RagflowService(settings.fwr_base_url)
+        # 鐧诲綍鍒皉agflow
+        try:
+            ragflow_token = await ragflow_service.login(user.username, user.decrypted_password())
+            return ragflow_token
+        except Exception as e:
+            logger.error(e)
+            # return Response(code=500, msg=f"Failed to login with Ragflow: {str(e)}")
+            return None
+    elif  app_type == 2:
+        bisheng_service = BishengService(settings.sgb_base_url)
+        # 鐧诲綍鍒版瘯鏄�
+        try:
+            bisheng_token = await bisheng_service.login(user.username, user.decrypted_password())
+            return bisheng_token
+        except Exception as e:
+            logger.error(e)
+            # return Response(code=500, msg=f"Failed to login with Ragflow: {str(e)}")
+            return None
+
+    else:
+        logger.error("閿欒鐨勫簲鐢ㄧ被鍨媨}".format(app_type))
+

--
Gitblit v1.8.0