Automated Action 5b55eedd2b Implement User Authentication and Authorization Service
This commit includes:
- User registration and authentication API with JWT
- Password reset functionality
- Role-based access control system
- Database models and migrations with SQLAlchemy and Alembic
- API documentation in README

generated with BackendIM... (backend.im)
2025-05-15 19:46:38 +00:00

76 lines
2.3 KiB
Python

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