mirror of
https://github.com/fastapi-practices/fastapi_best_architecture.git
synced 2025-08-18 23:11:48 +08:00

* [WIP] Add OAuth 2.0 authorization login * Add social user relationship table * Update social user relationship table back_populates * Add OAuth 2.0 related interface * Automatically redirect authorization addresses * Update OAuth2 authorization to GitHub * Add implementation code * fix the callback interface return * fix typo * fix the api return * fix imports * Fix logic for creating system users and social tables * Fix user information storage * Add OAuth2 source link * remove unnecessary db refresh * remove the front end docker-compose annotation
46 lines
1.9 KiB
Python
46 lines
1.9 KiB
Python
#!/usr/bin/env python3
|
|
# -*- coding: utf-8 -*-
|
|
from typing import Annotated
|
|
|
|
from fastapi import APIRouter, Depends, Query, Request
|
|
from fastapi.security import HTTPBasicCredentials
|
|
from fastapi_limiter.depends import RateLimiter
|
|
from starlette.background import BackgroundTasks
|
|
|
|
from backend.app.common.jwt import DependsJwtAuth
|
|
from backend.app.common.response.response_schema import ResponseModel, response_base
|
|
from backend.app.schemas.token import GetSwaggerToken
|
|
from backend.app.schemas.user import AuthLoginParam
|
|
from backend.app.services.auth_service import auth_service
|
|
|
|
router = APIRouter()
|
|
|
|
|
|
@router.post('/login/swagger', summary='swagger 调试专用', description='用于快捷获取 token 进行 swagger 认证')
|
|
async def swagger_user_login(obj: Annotated[HTTPBasicCredentials, Depends()]) -> GetSwaggerToken:
|
|
token, user = await auth_service.swagger_login(obj=obj)
|
|
return GetSwaggerToken(access_token=token, user=user) # type: ignore
|
|
|
|
|
|
@router.post(
|
|
'/login',
|
|
summary='用户登录',
|
|
description='json 格式登录, 仅支持在第三方api工具调试, 例如: postman',
|
|
dependencies=[Depends(RateLimiter(times=5, minutes=1))],
|
|
)
|
|
async def user_login(request: Request, obj: AuthLoginParam, background_tasks: BackgroundTasks) -> ResponseModel:
|
|
data = await auth_service.login(request=request, obj=obj, background_tasks=background_tasks)
|
|
return await response_base.success(data=data)
|
|
|
|
|
|
@router.post('/new_token', summary='创建新 token', dependencies=[DependsJwtAuth])
|
|
async def create_new_token(request: Request, refresh_token: Annotated[str, Query(...)]) -> ResponseModel:
|
|
data = await auth_service.new_token(request=request, refresh_token=refresh_token)
|
|
return await response_base.success(data=data)
|
|
|
|
|
|
@router.post('/logout', summary='用户登出', dependencies=[DependsJwtAuth])
|
|
async def user_logout(request: Request) -> ResponseModel:
|
|
await auth_service.logout(request=request)
|
|
return await response_base.success()
|