from sqlalchemy.ext.asyncio import create_async_engine, async_sessionmaker, AsyncSession from sqlalchemy.orm import DeclarativeBase from app.core.config import get_settings settings = get_settings() db_url = settings.DATABASE_URL_LOCAL if settings.DATABASE_URL_LOCAL else settings.DATABASE_URL engine_kwargs = {"echo": settings.DEBUG} if "sqlite" not in db_url: engine_kwargs["pool_size"] = 20 engine_kwargs["max_overflow"] = 10 engine = create_async_engine(db_url, **engine_kwargs) async_session = async_sessionmaker(engine, class_=AsyncSession, expire_on_commit=False) class Base(DeclarativeBase): pass async def get_db(): async with async_session() as session: try: yield session await session.commit() except Exception: await session.rollback() raise