add transport and strategy

This commit is contained in:
IluaAir
2025-06-22 12:50:51 +03:00
parent 4e2cee6625
commit 0a5e8a62eb
7 changed files with 36 additions and 20 deletions

View File

@@ -1,14 +1,13 @@
from typing import Annotated, AsyncGenerator
from fastapi import Depends
from fastapi_users.authentication.strategy import AccessTokenDatabase, DatabaseStrategy
from fastapi_users.authentication.strategy import AccessTokenDatabase
from fastapi_users_db_sqlalchemy import SQLAlchemyUserDatabase
from fastapi_users_db_sqlalchemy.access_token import SQLAlchemyAccessTokenDatabase
from sqlalchemy.ext.asyncio import AsyncSession
from src.db.database import async_session_maker
from src.models import UsersORM, AccessToken
from src.settings import settings
async def get_db() -> AsyncGenerator[AsyncSession, None]:
@@ -32,9 +31,3 @@ async def get_access_token_db(
ATDep = Annotated[AccessTokenDatabase[AccessToken], Depends(get_access_token_db)]
def get_database_strategy(
access_token_db: ATDep,
) -> DatabaseStrategy:
return DatabaseStrategy(access_token_db, lifetime_seconds=settings.lifetime)

View File

@@ -0,0 +1,21 @@
from fastapi import Depends
from fastapi_users.authentication import AuthenticationBackend
from fastapi_users.authentication.strategy import DatabaseStrategy, AccessTokenDatabase
from src.api.dependacies.dependancies import get_access_token_db
from src.api.dependacies.transport import bearer_transport
from src.models import AccessToken
from src.settings import settings
def get_database_strategy(
access_token_db: AccessTokenDatabase[AccessToken] = Depends(get_access_token_db),
) -> DatabaseStrategy:
return DatabaseStrategy(access_token_db, lifetime_seconds=settings.lifetime)
auth_backend = AuthenticationBackend(
name="database",
transport=bearer_transport,
get_strategy=get_database_strategy,
)

View File

@@ -0,0 +1,4 @@
from fastapi_users.authentication import BearerTransport
bearer_transport = BearerTransport(tokenUrl="auth/login")

View File

@@ -7,21 +7,21 @@ router = APIRouter(prefix="/tasks", tags=["Tasks"])
async def get_tasks(): ...
@router.get("/{task_id}")
async def get_task_id(task_id: int): ...
@router.get("/{id}")
async def get_task_id(id: int): ...
@router.post("/")
async def post_task(): ...
@router.put("/{task_id}")
async def put_task(task_id: int): ...
@router.put("/{id}")
async def put_task(id: int): ...
@router.patch("/{task_id}")
async def patch_task(task_id: int): ...
@router.patch("/{id}")
async def patch_task(id: int): ...
@router.delete("/{task_id}")
async def delete_task(task_id: int): ...
@router.delete("/{id}")
async def delete_task(id: int): ...

View File

@@ -3,7 +3,8 @@ from pydantic_settings import BaseSettings, SettingsConfigDict
class Settings(BaseSettings):
model_config = SettingsConfigDict(env_file='.env', env_file_encoding='utf-8')
lifetime: int
LIFETIME: int
SECRET: str
settings = Settings()

View File

@@ -1,3 +0,0 @@
from fastapi_users.authentication import BearerTransport
bearer_transport = BearerTransport(tokenUrl="auth/jwt/login")