auth
This commit is contained in:
@@ -1,7 +1,17 @@
|
||||
from typing import Annotated
|
||||
|
||||
from fastapi import Depends
|
||||
|
||||
from api.application.protocols.date_time import DateTimeProvider
|
||||
from api.application.protocols.jwt import JwtTokenProcessor
|
||||
from api.application.protocols.password_hasher import PasswordHasher
|
||||
from api.application.usecase.auth.auth_user import LoginUser
|
||||
from api.domain.user.repository import UserRepository
|
||||
from api.infrastructure.auth.jwt_processor import JoseJwtTokenProcessor
|
||||
from api.infrastructure.date_time import SystemDateTimeProvider, Timezone
|
||||
from api.infrastructure.dependencies.stub import Stub
|
||||
from api.infrastructure.security.password_hasher import Pbkdf2PasswordHasher
|
||||
from api.infrastructure.settings import Settings
|
||||
|
||||
|
||||
def get_password_hasher() -> PasswordHasher:
|
||||
@@ -10,3 +20,19 @@ def get_password_hasher() -> PasswordHasher:
|
||||
|
||||
def get_date_time_provider() -> DateTimeProvider:
|
||||
return SystemDateTimeProvider(Timezone.UTC)
|
||||
|
||||
|
||||
def get_jwt_token_processor(
|
||||
settings: Annotated[Settings, Depends(Stub(Settings))],
|
||||
date_time_provider: Annotated[DateTimeProvider, Depends(Stub(DateTimeProvider))],
|
||||
) -> JwtTokenProcessor:
|
||||
return JoseJwtTokenProcessor(
|
||||
jwt_options=settings.jwt, date_time_provider=date_time_provider
|
||||
)
|
||||
|
||||
|
||||
def get_user_login(
|
||||
user_repository: Annotated[UserRepository, Depends(Stub(UserRepository))],
|
||||
password_hasher: Annotated[PasswordHasher, Depends(Stub(PasswordHasher))],
|
||||
) -> LoginUser:
|
||||
return LoginUser(user_repository=user_repository, password_hasher=password_hasher)
|
||||
|
@@ -2,6 +2,7 @@ from sqlalchemy import text
|
||||
from sqlalchemy.ext.asyncio import AsyncSession
|
||||
|
||||
from api.domain.user import User, UserRepository
|
||||
from api.domain.user.model import UserEmail, UserFirstName, UserId
|
||||
|
||||
|
||||
class SqlAlchemyUserRepository(UserRepository):
|
||||
@@ -25,7 +26,17 @@ class SqlAlchemyUserRepository(UserRepository):
|
||||
)
|
||||
|
||||
async def get_user(self, filter: dict) -> User | None:
|
||||
pass
|
||||
stmt = text("""SELECT * FROM users WHERE email = :val""")
|
||||
result = await self.session.execute(stmt, {"val": filter["email"]})
|
||||
if not result:
|
||||
return None
|
||||
result = result.mappings().one()
|
||||
return User(
|
||||
id=UserId(result.id),
|
||||
name=UserFirstName(result.name),
|
||||
email=UserEmail(result.email),
|
||||
hashed_password=result.hashed_password,
|
||||
)
|
||||
|
||||
async def get_users(self) -> list[User]:
|
||||
return []
|
||||
|
Reference in New Issue
Block a user