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.
33 lines
923 B
Python
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()
|