docs/Docs_To_Review/local-backend-audit.md
This matrix tracks desktop parity by mapping src/services/*.ts consumers to api/*.js handlers and classifying each feature as:
| Priority | Feature / Panel | Service source(s) (src/services/*.ts) | API route(s) | API handler(s) (api/*.js) | Classification | Closure status |
|---|---|---|---|---|---|---|
| P1 | LiveNewsPanel | src/services/live-news.ts | /api/youtube/live | api/youtube/live.js | Fully local | ✅ Local endpoint available; channel-level video fallback already implemented. |
| P1 | MonitorPanel | None (panel-local keyword matching) | None | None | Fully local | ✅ Client-side only (no backend dependency). |
| P1 | StrategicRiskPanel cached overlays | src/services/cached-risk-scores.ts | /api/risk-scores | api/risk-scores.js | Requires user-provided API key | ✅ Explicit fallback: panel continues with local aggregate scoring when cache feed is unavailable. |
| P1 | Map layers (conflicts, outages, AIS, military flights) | src/services/conflicts.ts, src/services/outages.ts, src/services/ais.ts, src/services/military-flights.ts | /api/acled-conflict, /api/cloudflare-outages, /api/ais-snapshot, /api/opensky | api/acled-conflict.js, api/cloudflare-outages.js, api/ais-snapshot.js, api/opensky.js | Requires user-provided API key | ✅ Explicit fallback: unavailable feeds are disabled while map rendering remains active for local/static layers. |
| P2 | Summaries | src/services/summarization.ts | /api/groq-summarize, /api/openrouter-summarize | api/groq-summarize.js, api/openrouter-summarize.js | Requires user-provided API key | ✅ Explicit fallback chain: Groq → OpenRouter → browser model. |
| P2 | MarketPanel | src/services/markets.ts, src/services/polymarket.ts | /api/coingecko, /api/polymarket, /api/finnhub, /api/yahoo-finance | api/coingecko.js, api/polymarket.js, api/finnhub.js, api/yahoo-finance.js | Fully local | ✅ Multi-provider and cache-aware fetch behavior maintained in sidecar mode. |
| P3 | Flight enrichment | src/services/wingbits.ts | /api/wingbits | api/wingbits/[[...path]].js | Requires user-provided API key | ✅ Explicit fallback: heuristic-only classification mode. |
| P3 | OpenSky relay fallback path | src/services/military-flights.ts | /api/opensky | api/opensky.js | Requires cloud fallback | ✅ Relay fallback documented; no hard failure when relay is unavailable. |
ServiceStatusPanel so operators can see acceptance status and per-feature fallback behavior in desktop runtime.api/*.js handlers locally and only uses cloud fallback when handler execution or relay path fails.A desktop build is considered ready when all checks below are green:
These checks are now surfaced in the Service Status UI as “Desktop readiness”.