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

33 lines
923 B
Python

from sqlalchemy import create_engine
from sqlalchemy.orm import declarative_base, sessionmaker
from admin_app.core.settings import get_admin_settings
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,
)
AdminBase = declarative_base()