zhangqian
2024-10-12 f41ca9e5dc78baa5a50c32ed05c05876266c6dd4
app/api/auth.py
@@ -1,16 +1,13 @@
from typing import Dict
import json
from fastapi import APIRouter, Depends, HTTPException
from fastapi import APIRouter, Depends, Request
from fastapi.security import OAuth2PasswordBearer
from passlib.context import CryptContext
from sqlalchemy.orm import Session
from app.api import Response
from app.api import Response, pwd_context, oauth2_scheme, 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.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
@@ -18,8 +15,7 @@
router = APIRouter()
pwd_context = CryptContext(schemes=["bcrypt"], deprecated="auto")
oauth2_scheme = OAuth2PasswordBearer(tokenUrl="token")
@router.post("/register", response_model=Response)
@@ -74,11 +70,13 @@
        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": "",
    })