feat: migrate to Pydantic V2 and implement rate limiting middleware
- Migrate settings.py to Pydantic V2 (SettingsConfigDict, validation_alias) - Update config models to use @field_validator with @classmethod - Replace deprecated datetime.utcnow() with datetime.now(timezone.utc) - Migrate FastAPI app from @app.on_event to lifespan context manager - Implement comprehensive rate limiting middleware with: * Endpoint-specific rate limits (login: 5/min, register: 3/min) * IP-based and user-based tracking * Authenticated user multiplier (2x limits) * Bypass paths for health, docs, static, websocket endpoints * Rate limit headers in responses - Add 13 comprehensive tests for rate limiting (all passing) - Update instructions.md to mark completed tasks - Fix asyncio.create_task usage in anime_service.py All 714 tests passing. No deprecation warnings.
This commit is contained in:
@@ -3,7 +3,7 @@
|
||||
Tests cover password setup and validation, JWT token operations,
|
||||
session management, lockout mechanism, and error handling.
|
||||
"""
|
||||
from datetime import datetime, timedelta
|
||||
from datetime import datetime, timedelta, timezone
|
||||
|
||||
import pytest
|
||||
|
||||
@@ -217,8 +217,8 @@ class TestJWTTokens:
|
||||
|
||||
expired_payload = {
|
||||
"sub": "tester",
|
||||
"exp": int((datetime.utcnow() - timedelta(hours=1)).timestamp()),
|
||||
"iat": int(datetime.utcnow().timestamp()),
|
||||
"exp": int((datetime.now(timezone.utc) - timedelta(hours=1)).timestamp()),
|
||||
"iat": int(datetime.now(timezone.utc).timestamp()),
|
||||
}
|
||||
expired_token = jwt.encode(
|
||||
expired_payload, svc.secret, algorithm="HS256"
|
||||
|
||||
Reference in New Issue
Block a user