"""Alembic environment configuration for async SQLAlchemy with PostgreSQL.""" import asyncio import os from logging.config import fileConfig from alembic import context from sqlalchemy import pool from sqlalchemy.engine import Connection from sqlalchemy.ext.asyncio import async_engine_from_config # Import all models to register them with Base.metadata from app.database import Base import app.models.tenant # noqa: F401 import app.models.user # noqa: F401 import app.models.device # noqa: F401 import app.models.config_backup # noqa: F401 # this is the Alembic Config object, which provides # access to the values within the .ini file in use. config = context.config # Override sqlalchemy.url from DATABASE_URL env var if set (for Docker) if os.environ.get("DATABASE_URL"): config.set_main_option("sqlalchemy.url", os.environ["DATABASE_URL"]) # Interpret the config file for Python logging. if config.config_file_name is not None: fileConfig(config.config_file_name) # Add your model's MetaData object here for 'autogenerate' support target_metadata = Base.metadata def run_migrations_offline() -> None: """Run migrations in 'offline' mode.""" url = config.get_main_option("sqlalchemy.url") context.configure( url=url, target_metadata=target_metadata, literal_binds=True, dialect_opts={"paramstyle": "named"}, ) with context.begin_transaction(): context.run_migrations() def do_run_migrations(connection: Connection) -> None: context.configure(connection=connection, target_metadata=target_metadata) with context.begin_transaction(): context.run_migrations() async def run_async_migrations() -> None: """Run migrations in 'online' mode with async engine.""" connectable = async_engine_from_config( config.get_section(config.config_ini_section, {}), prefix="sqlalchemy.", poolclass=pool.NullPool, ) async with connectable.connect() as connection: await connection.run_sync(do_run_migrations) await connectable.dispose() def run_migrations_online() -> None: """Run migrations in 'online' mode.""" asyncio.run(run_async_migrations()) if context.is_offline_mode(): run_migrations_offline() else: run_migrations_online()