# VPS Health API API sante minimaliste pour le VPS. ~127 lignes, Node 22 + HTTP natif. ## Endpoints - `GET /health` — CPU, memoire, disque, uptime, logto (`{status, responseTimeMs, error?}`) - `GET /defenseurs` — contenu de status.json (rapports defenseurs) - `GET /reports/scans?date=YYYY-MM-DD` — agrege les rapports `defenseur-_*.json` du jour, format `{ date, count, reports: Report[] }`. Filtre `isScanReport` (exclut `defenseur-auto_*.json`). Date validee par regex (path traversal bloque). Consommateur : `defenseur-auto` workstation cron (remplace le pre-rsync SSH). Exemple : `curl -H "Authorization: Bearer $TOKEN" "https://health.lacompagniemaximus.com/reports/scans?date=2026-05-07"`. ## Auth - Bearer token via env `HEALTH_TOKEN` - Fail-closed : si `HEALTH_TOKEN` non configure, toutes les requetes sont refusees - **Coolify** : `HEALTH_TOKEN` doit etre `is_runtime=true, is_buildtime=false`. Buildtime fait fuiter le secret en clair dans `application_deployment_queues.logs`. Voir `la-compagnie-maximus/docs/coolify-ops.md` section "Secrets en buildtime". ## Config - Port : `3001` (env `PORT`) - `LOGTO_HEALTH_URL` : URL du `.well-known/openid-configuration` (default auth.lacompagniemaximus.com) - `REPORTS_DIR` : dossier lu par `/reports/scans` (default `/data/defenseurs/reports`) - Bind-mount : `/data/defenseurs/` (status.json + reports/) read-only ## Deploy Coolify auto-rebuild depuis push Forgejo. Aucune action manuelle requise. ## Gotchas - Pas d'Express — HTTP natif Node.js uniquement - Le `status.json` est ecrit par le Sergent defenseurs, pas par cette API (read-only)