This commit is contained in:
2024-04-04 10:51:51 +00:00
parent b04eba9bc4
commit f8f5bf80c1
6 changed files with 74 additions and 37 deletions

View File

@@ -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)

View File

@@ -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 []