|
| 1 | +from typing import Annotated |
| 2 | + |
| 3 | +from fastapi import APIRouter, Depends, status |
| 4 | +from fastapi.security import OAuth2PasswordRequestForm |
| 5 | +from sqlalchemy.ext.asyncio import AsyncSession |
| 6 | + |
| 7 | +from app.core.database import get_session |
| 8 | +from app.core.exceptions import CredentialsError |
| 9 | +from app.core.security import create_access_token |
| 10 | +from app.services.user.models import User |
| 11 | +from app.services.user.schemas import Token, UserCreate, UserRead |
| 12 | +from app.services.user.service import UserService |
| 13 | +from app.shared.deps import get_current_user |
| 14 | + |
| 15 | +router_v1 = APIRouter() |
| 16 | + |
| 17 | + |
| 18 | +@router_v1.post('/users', status_code=status.HTTP_201_CREATED) |
| 19 | +async def create_user( |
| 20 | + user_create: UserCreate, session: Annotated[AsyncSession, Depends(get_session)] |
| 21 | +) -> UserRead: |
| 22 | + user = await UserService.create_user(session, user_create) |
| 23 | + return UserRead.model_validate(user) |
| 24 | + |
| 25 | + |
| 26 | +@router_v1.post('/auth/token') |
| 27 | +async def login( |
| 28 | + form_data: Annotated[OAuth2PasswordRequestForm, Depends()], |
| 29 | + session: Annotated[AsyncSession, Depends(get_session)], |
| 30 | +) -> Token: |
| 31 | + user = await UserService.authenticate_user( |
| 32 | + session, form_data.username, form_data.password |
| 33 | + ) |
| 34 | + if not user: |
| 35 | + raise CredentialsError() |
| 36 | + access_token = create_access_token(data={'sub': str(user.email)}) |
| 37 | + return Token(access_token=access_token, token_type='bearer') |
| 38 | + |
| 39 | + |
| 40 | +@router_v1.get('/users/me') |
| 41 | +async def read_user_me( |
| 42 | + current_user: Annotated[User, Depends(get_current_user)], |
| 43 | +) -> UserRead: |
| 44 | + return UserRead.model_validate(current_user) |
0 commit comments