""" Configuration de la base de données """ from sqlalchemy import create_engine from sqlalchemy.ext.declarative import declarative_base from sqlalchemy.orm import sessionmaker import os from dotenv import load_dotenv load_dotenv() # URL de la base de données (PostgreSQL en production) DATABASE_URL = os.getenv("DATABASE_URL", "postgresql://user:password@localhost:5432/anime_tracker") # Configuration du moteur SQLAlchemy if DATABASE_URL.startswith("sqlite"): # SQLite pour développement local engine = create_engine( DATABASE_URL, connect_args={"check_same_thread": False} ) elif DATABASE_URL.startswith("postgresql"): # PostgreSQL avec pool de connexions engine = create_engine( DATABASE_URL, pool_pre_ping=True, # Vérifier les connexions avant utilisation pool_recycle=3600, # Recycler les connexions après 1 heure pool_size=10, # Taille du pool de connexions max_overflow=20 # Nombre maximum de connexions supplémentaires ) else: engine = create_engine(DATABASE_URL) SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine) Base = declarative_base() def get_db(): """Dépendance pour obtenir une session de base de données""" db = SessionLocal() try: yield db finally: db.close() def init_db(): """Initialiser la base de données (créer les tables)""" from models import User, Anime Base.metadata.create_all(bind=engine)