- "backend/models.py" - "backend/database.py" - "alembic/versions/001_initial.py" - "alembic/env.py" - "alembic.ini" - "alembic/script.py.mako" - "docker-compose.yml" - ".gsd/KNOWLEDGE.md" GSD-Task: S01/T02
26 lines
791 B
Python
26 lines
791 B
Python
"""Database engine, session factory, and declarative base for Chrysopedia."""
|
|
|
|
import os
|
|
|
|
from sqlalchemy.ext.asyncio import AsyncSession, async_sessionmaker, create_async_engine
|
|
from sqlalchemy.orm import DeclarativeBase
|
|
|
|
DATABASE_URL = os.getenv(
|
|
"DATABASE_URL",
|
|
"postgresql+asyncpg://chrysopedia:changeme@localhost:5433/chrysopedia",
|
|
)
|
|
|
|
engine = create_async_engine(DATABASE_URL, echo=False, pool_pre_ping=True)
|
|
|
|
async_session = async_sessionmaker(engine, class_=AsyncSession, expire_on_commit=False)
|
|
|
|
|
|
class Base(DeclarativeBase):
|
|
"""Declarative base for all ORM models."""
|
|
pass
|
|
|
|
|
|
async def get_session() -> AsyncSession: # type: ignore[misc]
|
|
"""FastAPI dependency that yields an async DB session."""
|
|
async with async_session() as session:
|
|
yield session
|