Files
Messenger/app/auth/schemas.py
benya 27d3340a37
Some checks failed
CI / test (push) Failing after 21s
feat(auth): add TOTP 2FA setup and login verification
- add user twofa fields and migration

- add 2FA setup/enable/disable endpoints

- enforce OTP on login when 2FA enabled

- add web login OTP field and settings UI
2026-03-08 11:43:51 +03:00

79 lines
1.7 KiB
Python

from datetime import datetime
from pydantic import BaseModel, ConfigDict, EmailStr, Field
class RegisterRequest(BaseModel):
email: EmailStr
name: str = Field(min_length=1, max_length=100)
username: str = Field(min_length=3, max_length=50)
password: str = Field(min_length=8, max_length=128)
class LoginRequest(BaseModel):
email: EmailStr
password: str = Field(min_length=8, max_length=128)
otp_code: str | None = Field(default=None, min_length=6, max_length=8)
class RefreshTokenRequest(BaseModel):
refresh_token: str = Field(min_length=16)
class VerifyEmailRequest(BaseModel):
token: str = Field(min_length=16, max_length=512)
class ResendVerificationRequest(BaseModel):
email: EmailStr
class RequestPasswordResetRequest(BaseModel):
email: EmailStr
class ResetPasswordRequest(BaseModel):
token: str = Field(min_length=16, max_length=512)
new_password: str = Field(min_length=8, max_length=128)
class MessageResponse(BaseModel):
message: str
class TokenResponse(BaseModel):
access_token: str
refresh_token: str
token_type: str = "bearer"
class AuthUserResponse(BaseModel):
model_config = ConfigDict(from_attributes=True)
id: int
email: EmailStr
name: str
username: str
bio: str | None = None
avatar_url: str | None = None
email_verified: bool
twofa_enabled: bool
created_at: datetime
updated_at: datetime
class SessionRead(BaseModel):
jti: str
created_at: datetime
ip_address: str | None = None
user_agent: str | None = None
class TwoFactorSetupRead(BaseModel):
secret: str
otpauth_url: str
class TwoFactorCodeRequest(BaseModel):
code: str = Field(min_length=6, max_length=8)