Spaces:
Running
Running
File size: 700 Bytes
2ae523d 647ee84 126d97e 2ae523d 1248f52 2ae523d 126d97e 647ee84 2ae523d 1248f52 2ae523d | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | from typing import Generator
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker, Session
from contextlib import contextmanager
from dotenv import load_dotenv
import os
load_dotenv()
def get_engine():
database_url = os.getenv("DATABASE_URL")
if not database_url:
raise ValueError("DATABASE_URL is not set in environment variables")
return create_engine(database_url)
@contextmanager
def get_session() -> Generator[Session, None, None]:
"""
Get a connection to the Postgres database
"""
engine = get_engine()
SessionLocal = sessionmaker(bind=engine)
db = SessionLocal()
try:
yield db
finally:
db.close()
|