2025-10-03 14:09:34 +02:00
|
|
|
"""
|
|
|
|
|
Demo Session Service - Main Application
|
|
|
|
|
Manages isolated demo sessions with ephemeral data
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
import structlog
|
|
|
|
|
|
2025-10-15 16:12:49 +02:00
|
|
|
from app.core import settings, DatabaseManager
|
2025-11-30 09:12:40 +01:00
|
|
|
from app.api import demo_sessions, demo_accounts, demo_operations, internal
|
2025-10-15 16:12:49 +02:00
|
|
|
from shared.redis_utils import initialize_redis, close_redis
|
2026-01-09 23:14:12 +01:00
|
|
|
from shared.service_base import StandardFastAPIService
|
2025-10-03 14:09:34 +02:00
|
|
|
|
2026-01-09 23:14:12 +01:00
|
|
|
# Initialize logger
|
|
|
|
|
logger = structlog.get_logger()
|
2025-10-03 14:09:34 +02:00
|
|
|
|
2026-01-09 23:14:12 +01:00
|
|
|
# Initialize database manager
|
|
|
|
|
db_manager = DatabaseManager()
|
2025-10-03 14:09:34 +02:00
|
|
|
|
|
|
|
|
|
2026-01-09 23:14:12 +01:00
|
|
|
class DemoSessionService(StandardFastAPIService):
|
|
|
|
|
"""Demo Session Service with standardized monitoring setup"""
|
2026-01-08 20:48:24 +01:00
|
|
|
|
2026-01-09 23:14:12 +01:00
|
|
|
async def on_startup(self, app):
|
|
|
|
|
"""Custom startup logic for Demo Session"""
|
|
|
|
|
# Initialize database
|
|
|
|
|
db_manager.initialize()
|
|
|
|
|
logger.info("Database initialized")
|
2026-01-08 12:58:00 +01:00
|
|
|
|
2026-01-09 23:14:12 +01:00
|
|
|
# Initialize Redis
|
|
|
|
|
await initialize_redis(
|
|
|
|
|
redis_url=settings.REDIS_URL,
|
|
|
|
|
db=0,
|
|
|
|
|
max_connections=50
|
|
|
|
|
)
|
|
|
|
|
logger.info("Redis initialized")
|
2025-10-03 14:09:34 +02:00
|
|
|
|
2026-01-09 23:14:12 +01:00
|
|
|
await super().on_startup(app)
|
2025-10-03 14:09:34 +02:00
|
|
|
|
2026-01-09 23:14:12 +01:00
|
|
|
async def on_shutdown(self, app):
|
|
|
|
|
"""Custom shutdown logic for Demo Session"""
|
|
|
|
|
await super().on_shutdown(app)
|
2025-10-03 14:09:34 +02:00
|
|
|
|
2026-01-09 23:14:12 +01:00
|
|
|
# Cleanup
|
|
|
|
|
await db_manager.close()
|
|
|
|
|
await close_redis()
|
|
|
|
|
logger.info("Database and Redis connections closed")
|
2025-10-03 14:09:34 +02:00
|
|
|
|
|
|
|
|
|
2026-01-09 23:14:12 +01:00
|
|
|
# Create service instance
|
|
|
|
|
service = DemoSessionService(
|
|
|
|
|
service_name="demo-session",
|
|
|
|
|
app_name="Demo Session Service",
|
2025-10-03 14:09:34 +02:00
|
|
|
description="Manages isolated demo sessions for prospect users",
|
|
|
|
|
version=settings.VERSION,
|
2026-01-09 23:14:12 +01:00
|
|
|
log_level=getattr(settings, 'LOG_LEVEL', 'INFO'),
|
|
|
|
|
cors_origins=["*"], # Configure appropriately for production
|
|
|
|
|
api_prefix="/api/v1",
|
|
|
|
|
enable_metrics=True,
|
|
|
|
|
enable_health_checks=True,
|
|
|
|
|
enable_tracing=True,
|
|
|
|
|
enable_cors=True
|
2025-10-03 14:09:34 +02:00
|
|
|
)
|
|
|
|
|
|
2026-01-09 23:14:12 +01:00
|
|
|
# Create FastAPI app
|
|
|
|
|
app = service.create_app(debug=settings.DEBUG)
|
2025-10-03 14:09:34 +02:00
|
|
|
|
2026-01-09 23:14:12 +01:00
|
|
|
# Add service-specific routers
|
2025-10-06 15:27:01 +02:00
|
|
|
app.include_router(demo_sessions.router)
|
|
|
|
|
app.include_router(demo_accounts.router)
|
|
|
|
|
app.include_router(demo_operations.router)
|
2025-11-30 09:12:40 +01:00
|
|
|
app.include_router(internal.router)
|
2025-10-03 14:09:34 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
|
import uvicorn
|
|
|
|
|
uvicorn.run(
|
|
|
|
|
"app.main:app",
|
|
|
|
|
host="0.0.0.0",
|
|
|
|
|
port=8000,
|
|
|
|
|
reload=settings.DEBUG,
|
|
|
|
|
log_level=settings.LOG_LEVEL.lower()
|
|
|
|
|
)
|