register_data: UserRegisterSchema,
pwd_context: CryptContext = Depends(),
session: Session = Depends(),
mail: FastMail = Depends(),
):
register_data_dict: dict = register_data.dict()
user_password: str = register_data_dict.get("password")
register_data_dict["password"] = User.hash_password(user_password, pwd_context)
register_data_dict["joined_at"] = datetime.datetime.utcnow()
try:
await create_user(session, register_data_dict)
except DBAPIError as exc:
return {"status": "failed", "details": str(exc)}
return {"status": "ok"}
выглядит как будто create_user мог быть прикладным слоем, но у тебя это сразу работа с БД
короче, у тебя нет прикладного слоя, его логика размазана между слоем работы с БД и вьюхами
крейт юзер воть async def create_user( session: Session, user: dict, ) -> None: """ Register user """ user_obj = User( email=user.get("email"), password=user.get("password"), first_name=user.get("first_name"), last_name=user.get("last_name"), joined_at=user.get("joined_at"), is_superuser=user.get("is_superuser"), is_active=user.get("is_active"), ) session.add(user_obj) await session.commit()
и где мне тогда отправлять почту?
в том слое, где у тебя планируется бизнес логика
Почитай про слой сервисов у Фаулера. Тишка хочет сказать что вот то месиво в register это по сути и есть твоя бизнес-логика и тебе надо куда-то вынести ее и там делать в т.ч. отправку почты.
и куда мне ее выносить? в отдельный слой? как он должен называться?
мне не в тестах это надо
Ну тут уже сам ориентируйся
Обсуждают сегодня