Some checks failed
CI / test (push) Failing after 33s
- store refresh session metadata in redis (ip/user-agent/created_at) - add auth APIs: list sessions, revoke one, revoke all - add web privacy UI for active sessions
68 lines
1.4 KiB
Python
68 lines
1.4 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)
|
|
|
|
|
|
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
|
|
created_at: datetime
|
|
updated_at: datetime
|
|
|
|
|
|
class SessionRead(BaseModel):
|
|
jti: str
|
|
created_at: datetime
|
|
ip_address: str | None = None
|
|
user_agent: str | None = None
|