| | |
| | | from typing import Dict |
| | | import json |
| | | |
| | | from fastapi import APIRouter, Depends, HTTPException |
| | | from fastapi.security import OAuth2PasswordBearer |
| | | from passlib.context import CryptContext |
| | | from fastapi import APIRouter, Depends |
| | | from sqlalchemy.orm import Session |
| | | |
| | | from app.api import Response |
| | | from app.api import Response, pwd_context, get_current_user |
| | | from app.config.config import settings |
| | | from app.models.base_model import get_db |
| | | from app.models.token_model import upsert_token |
| | | from app.models.user import User, UserCreate, LoginData |
| | | from app.models.token_model import upsert_token, get_token |
| | | from app.models.user import UserCreate, LoginData |
| | | from app.models.user_model import UserModel |
| | | from app.service.auth import authenticate_user, create_access_token |
| | | from app.service.bisheng import BishengService |
| | | from app.service.ragflow import RagflowService |
| | | |
| | | router = APIRouter() |
| | | |
| | | pwd_context = CryptContext(schemes=["bcrypt"], deprecated="auto") |
| | | oauth2_scheme = OAuth2PasswordBearer(tokenUrl="token") |
| | | |
| | | |
| | | @router.post("/register", response_model=Response) |
| | |
| | | return Response(code=500, msg=f"Failed to login with Ragflow: {str(e)}") |
| | | |
| | | # 创建本地token |
| | | access_token = create_access_token(data={"sub": user.username}) |
| | | access_token = create_access_token(data={"sub": user.username, "user_id": user.id}) |
| | | |
| | | upsert_token(db, user.id, access_token, bisheng_token, ragflow_token) |
| | | |
| | | return Response(code=200, msg="Login successful", data={ |
| | | "access_token": access_token, |
| | | "token_type": "bearer" |
| | | "token_type": "bearer", |
| | | "username": user.username, |
| | | "nickname": "", |
| | | }) |
| | | |
| | | |
| | | @router.get("/token", response_model=Response) |
| | | async def token_api(db: Session = Depends(get_db), current_user: UserModel = Depends(get_current_user)): |
| | | # 查询现有记录 |
| | | token = get_token(db, current_user.id) |
| | | if token is None: |
| | | return Response(code=400, msg="token not found") |
| | | return Response(code=200, msg="success", data={ |
| | | "ragflow_token": token.ragflow_token, |
| | | }) |