from datetime import datetime from typing import List, Optional from pydantic import BaseModel, EmailStr, Field, validator # Shared properties class UserBase(BaseModel): email: Optional[EmailStr] = None is_active: Optional[bool] = True first_name: Optional[str] = None last_name: Optional[str] = None # Properties to receive via API on creation class UserCreate(BaseModel): email: EmailStr password: str = Field(..., min_length=8) first_name: Optional[str] = None last_name: Optional[str] = None @validator("password") def password_strength(cls, v): """Validate password strength.""" if len(v) < 8: raise ValueError("Password must be at least 8 characters long") if not any(char.isdigit() for char in v): raise ValueError("Password must contain at least one digit") if not any(char.isupper() for char in v): raise ValueError("Password must contain at least one uppercase letter") if not any(char.islower() for char in v): raise ValueError("Password must contain at least one lowercase letter") return v # Properties to receive via API on update class UserUpdate(UserBase): password: Optional[str] = None @validator("password") def password_strength(cls, v): """Validate password strength if provided.""" if v is None: return v if len(v) < 8: raise ValueError("Password must be at least 8 characters long") if not any(char.isdigit() for char in v): raise ValueError("Password must contain at least one digit") if not any(char.isupper() for char in v): raise ValueError("Password must contain at least one uppercase letter") if not any(char.islower() for char in v): raise ValueError("Password must contain at least one lowercase letter") return v # Properties shared by models stored in DB class UserInDBBase(UserBase): id: int email: EmailStr is_active: bool is_verified: bool created_at: datetime updated_at: datetime class Config: orm_mode = True # Properties to return via API class User(UserInDBBase): pass # Properties stored in DB class UserInDB(UserInDBBase): hashed_password: str