Spaces:
Running
Running
from fastapi import HTTPException | |
from trauma.api.account.model import AccountModel | |
from trauma.api.security.schemas import LoginAccountRequest | |
from trauma.core.config import settings | |
from trauma.core.security import verify_password | |
async def authenticate_account(data: LoginAccountRequest) -> AccountModel: | |
account = await settings.DB_CLIENT.accounts.find_one( | |
{"email": data.email}, | |
collation={"locale": "en", "strength": 2}) | |
if account is None: | |
raise HTTPException(status_code=404, detail="Invalid email or password.") | |
account = AccountModel.from_mongo(account) | |
if not verify_password(data.password, account.password): | |
raise HTTPException(status_code=401, detail="Invalid email or password.") | |
return account | |