ALwrity LinkedIn Writer: Billing Dashboard: Compact View, Billing Overview, System Health Indicator, Cost Breakdown, Usage Trends, Usage Alerts, Comprehensive API Breakdown

This commit is contained in:
ajaysi
2025-09-11 11:09:10 +05:30
parent b156298e82
commit 1b65a9487b
84 changed files with 10143 additions and 156 deletions

View File

@@ -23,12 +23,23 @@ from models.subscription_models import Base as SubscriptionBase
# Database configuration
DATABASE_URL = os.getenv('DATABASE_URL', 'sqlite:///./alwrity.db')
# Create engine
# Create engine with safer pooling defaults and SQLite-friendly settings
engine_kwargs = {
"echo": False, # Set to True for SQL debugging
"pool_pre_ping": True, # Detect stale connections
"pool_recycle": 300, # Recycle connections to avoid timeouts
"pool_size": int(os.getenv("DB_POOL_SIZE", "20")),
"max_overflow": int(os.getenv("DB_MAX_OVERFLOW", "40")),
"pool_timeout": int(os.getenv("DB_POOL_TIMEOUT", "30")),
}
# SQLite needs special handling for multithreaded FastAPI
if DATABASE_URL.startswith("sqlite"):
engine_kwargs["connect_args"] = {"check_same_thread": False}
engine = create_engine(
DATABASE_URL,
echo=False, # Set to True for SQL debugging
pool_pre_ping=True,
pool_recycle=300,
**engine_kwargs,
)
# Create session factory