bmc_hub/app/system/backend/router.py

108 lines
3.0 KiB
Python
Raw Normal View History

2025-12-05 14:22:39 +01:00
"""
System Router
Health checks and system information
"""
from fastapi import APIRouter
from app.core.config import settings
from app.core.database import execute_query
router = APIRouter()
@router.get("/system/health")
async def health_check():
"""Comprehensive health check"""
try:
# Test database connection
result = execute_query("SELECT 1 as test")
db_status = "healthy" if result else "unhealthy"
except Exception as e:
db_status = f"unhealthy: {str(e)}"
return {
"status": "healthy",
"service": "BMC Hub",
"version": "1.0.0",
"database": db_status,
"config": {
"environment": "production" if not settings.ECONOMIC_DRY_RUN else "development",
"economic_read_only": settings.ECONOMIC_READ_ONLY,
"economic_dry_run": settings.ECONOMIC_DRY_RUN
}
}
@router.get("/system/config")
async def get_config():
"""Get system configuration (non-sensitive)"""
return {
"api_host": settings.API_HOST,
"api_port": settings.API_PORT,
"log_level": settings.LOG_LEVEL,
"economic_enabled": bool(settings.ECONOMIC_APP_SECRET_TOKEN),
"economic_read_only": settings.ECONOMIC_READ_ONLY,
"economic_dry_run": settings.ECONOMIC_DRY_RUN
}
@router.get("/system/maintenance")
async def get_maintenance_status():
"""Get maintenance mode status"""
return {
"maintenance_mode": False,
"message": None
}
@router.get("/system/live-stats")
async def get_live_stats():
"""Get live dashboard statistics"""
try:
# Get counts from database
customers_result = execute_query("SELECT COUNT(*) as count FROM customers")
tickets_result = execute_query("SELECT COUNT(*) as count FROM tickets WHERE status != 'closed'")
return {
"sales": {
"active_orders": 0,
"pending_quotes": 0
},
"customers": {
"total": customers_result[0]['count'] if customers_result else 0,
"new_this_month": 0
},
"tickets": {
"open": tickets_result[0]['count'] if tickets_result else 0,
"in_progress": 0
}
}
except Exception as e:
return {
"sales": {"active_orders": 0, "pending_quotes": 0},
"customers": {"total": 0, "new_this_month": 0},
"tickets": {"open": 0, "in_progress": 0}
}
@router.get("/system/recent-activity")
async def get_recent_activity():
"""Get recent system activity"""
try:
# Get recent customers
query = """
SELECT
'customer' as activity_type,
name,
created_at,
'bi-building' as icon,
'primary' as color
FROM customers
ORDER BY created_at DESC
LIMIT 10
"""
activities = execute_query(query)
return activities
except Exception as e:
return []