Spaces:
Sleeping
Sleeping
File size: 1,896 Bytes
f2b5c2a | 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 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 | """
Database configuration and session management.
This module provides:
- Database engine creation
- Session management
- Dependency injection for FastAPI routes
"""
import os
from typing import Generator
from sqlmodel import Session, create_engine, SQLModel
# Get database URL from environment variable
# For Vercel serverless, use /tmp directory for SQLite
# For Hugging Face Spaces, use /app/data directory
DATABASE_URL = os.getenv("DATABASE_URL")
if DATABASE_URL is None:
# Check if running on Vercel (serverless environment)
if os.getenv("VERCEL"):
# Use /tmp directory which is writable in Vercel serverless
DATABASE_URL = "sqlite:////tmp/todo.db"
# Check if running on Hugging Face Spaces
elif os.getenv("SPACE_ID") or os.path.exists("/app/data"):
# Use /app/data directory for persistent storage on HF Spaces
DATABASE_URL = "sqlite:////app/data/todo.db"
else:
# Local development
DATABASE_URL = "sqlite:///./todo.db"
# Create database engine
# connect_args only needed for SQLite
connect_args = {"check_same_thread": False} if DATABASE_URL.startswith("sqlite") else {}
engine = create_engine(
DATABASE_URL,
echo=False, # Disable SQL query logging for serverless
connect_args=connect_args,
pool_pre_ping=True, # Verify connections before using
)
def create_db_and_tables():
"""Create all database tables."""
SQLModel.metadata.create_all(engine)
def get_session() -> Generator[Session, None, None]:
"""
Dependency function to provide database session to FastAPI routes.
Yields:
Session: SQLModel database session
Example:
@app.get("/items")
def get_items(session: Session = Depends(get_session)):
items = session.exec(select(Item)).all()
return items
"""
with Session(engine) as session:
yield session
|