language-learning-app/api/app/outbound/postgres/database.py

30 lines
604 B
Python
Raw Normal View History

from collections.abc import AsyncGenerator
from sqlalchemy.ext.asyncio import (
AsyncEngine,
AsyncSession,
async_sessionmaker,
create_async_engine,
)
2026-03-18 20:55:02 +00:00
from sqlalchemy.orm import DeclarativeBase
from ...config import settings
2026-03-18 20:55:02 +00:00
engine: AsyncEngine = create_async_engine(
settings.database_url,
pool_pre_ping=True,
)
AsyncSessionLocal = async_sessionmaker[AsyncSession](
engine,
expire_on_commit=False,
)
2026-03-18 20:55:02 +00:00
class Base(DeclarativeBase):
pass
async def get_db() -> AsyncGenerator[AsyncSession, None]:
2026-03-18 20:55:02 +00:00
async with AsyncSessionLocal() as session:
yield session