24 lines
551 B
Python
24 lines
551 B
Python
|
|
"""Database connection for the integrator."""
|
||
|
|
from contextlib import contextmanager
|
||
|
|
|
||
|
|
from sqlalchemy import create_engine
|
||
|
|
from sqlalchemy.orm import sessionmaker
|
||
|
|
|
||
|
|
from config import DATABASE_URL
|
||
|
|
|
||
|
|
engine = create_engine(DATABASE_URL, pool_pre_ping=True)
|
||
|
|
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
|
||
|
|
|
||
|
|
|
||
|
|
@contextmanager
|
||
|
|
def get_session():
|
||
|
|
session = SessionLocal()
|
||
|
|
try:
|
||
|
|
yield session
|
||
|
|
session.commit()
|
||
|
|
except Exception:
|
||
|
|
session.rollback()
|
||
|
|
raise
|
||
|
|
finally:
|
||
|
|
session.close()
|