You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
orquestrador/admin_app/db/database.py

56 lines
1.6 KiB
Python

from collections.abc import Generator
from sqlalchemy import create_engine, event
from sqlalchemy.orm import Session, declarative_base, sessionmaker
from admin_app.core.settings import get_admin_settings
from admin_app.db.write_governance import enforce_admin_session_write_governance
# monta a conexão do banco administrativo e expõe get_admin_db_session(). Esse generator é o que alimenta as dependências FastAPI para repositórios e serviços.
settings = get_admin_settings()
admin_cloud_sql = settings.admin_db_cloud_sql_connection_name
if admin_cloud_sql:
ADMIN_DATABASE_URL = (
f"mysql+pymysql://{settings.admin_db_user}:{settings.admin_db_password}@/{settings.admin_db_name}"
f"?unix_socket=/cloudsql/{admin_cloud_sql}"
)
else:
ADMIN_DATABASE_URL = (
f"mysql+pymysql://{settings.admin_db_user}:{settings.admin_db_password}@"
f"{settings.admin_db_host}:{settings.admin_db_port}/{settings.admin_db_name}"
)
admin_engine = create_engine(
ADMIN_DATABASE_URL,
pool_pre_ping=True,
connect_args={"connect_timeout": 5},
)
AdminSessionLocal = sessionmaker(
autocommit=False,
autoflush=False,
bind=admin_engine,
)
@event.listens_for(AdminSessionLocal, "before_flush")
def _block_unguarded_admin_writes(session, flush_context, instances):
enforce_admin_session_write_governance(
new=session.new,
dirty=session.dirty,
deleted=session.deleted,
)
AdminBase = declarative_base()
def get_admin_db_session() -> Generator[Session, None, None]:
db = AdminSessionLocal()
try:
yield db
finally:
db.close()