{"ts":"2026-05-28T09:58:07.421Z","level":"INFO","msg":"[ORGS] Loaded 1 org(s) from /app/data/orgs.json"}
{"ts":"2026-05-28T09:58:09.230Z","level":"INFO","msg":"[EDIFACT] Loaded 34098 stations (403 NL) from /app/tsdupd.r"}
{"ts":"2026-05-28T09:58:09.319Z","level":"INFO","msg":"\n🚂 RTMDE Train Tracker Server"}
{"ts":"2026-05-28T09:58:09.319Z","level":"INFO","msg":"   No config loaded — upload via UI"}
{"ts":"2026-05-28T09:58:09.319Z","level":"INFO","msg":"   URL: http://localhost:3000\n"}
{"ts":"2026-05-28T09:58:09.320Z","level":"INFO","msg":"   Memory: 108 MB RSS, 710 MB available\n"}
{"ts":"2026-05-28T09:58:09.320Z","level":"INFO","msg":"[OSM] Downloading railway network from Overpass (may take ~30s)…"}
{"ts":"2026-05-28T09:58:09.475Z","level":"INFO","msg":"[ANALYTICS] DB ready: /app/data/analytics.db"}
{"ts":"2026-05-28T09:59:21.224Z","level":"INFO","msg":"[OSM] Downloaded 47386 ways → saved to cache"}
{"ts":"2026-05-28T09:59:21.225Z","level":"WARN","msg":"[OSM] Low memory (239 MB available) — skipping graph build to protect server"}
{"ts":"2026-05-28T10:17:37.274Z","level":"INFO","msg":"[CONFIG] Saved config to /app/data/config.json (2 env(s))"}
{"ts":"2026-05-28T10:17:37.275Z","level":"INFO","msg":"[DEBUG] [ACC] Consumer → POST https://f9xmg08gbd.execute-api.eu-central-1.amazonaws.com/acc/login body: {\"username\":\"3630\",\"password\":\"***\"}"}
{"ts":"2026-05-28T10:17:37.877Z","level":"INFO","msg":"[DEBUG] [ACC] Consumer ← OK (token received, expires in ~60 min)"}
{"ts":"2026-05-28T10:17:37.877Z","level":"INFO","msg":"[DEBUG] [ACC] Provider → POST https://d39sfqhkjg.execute-api.eu-central-1.amazonaws.com/acc/login body: {\"username\":\"3630\",\"password\":\"***\"}"}
{"ts":"2026-05-28T10:17:38.356Z","level":"INFO","msg":"[DEBUG] [ACC] Provider ← OK (token received, expires in ~60 min)"}
{"ts":"2026-05-28T10:17:38.356Z","level":"INFO","msg":"[DEBUG] [PRD] Consumer → POST https://ws-consumer.rtmde.hitrail.com/login body: {\"username\":\"3630\",\"password\":\"***\"}"}
{"ts":"2026-05-28T10:17:38.893Z","level":"INFO","msg":"[DEBUG] [PRD] Consumer ← OK (token received, expires in ~60 min)"}
{"ts":"2026-05-28T10:17:38.893Z","level":"INFO","msg":"[DEBUG] [PRD] Provider → POST https://ws-provider.rtmde.hitrail.com/login body: {\"username\":\"urn:uic:rics:3630\",\"password\":\"***\"}"}
{"ts":"2026-05-28T10:17:39.407Z","level":"INFO","msg":"[DEBUG] [PRD] Provider ← OK (token received, expires in ~60 min)"}
{"ts":"2026-05-28T10:17:39.407Z","level":"INFO","msg":"[POLL] Scheduled [ACC] every 5 min"}
{"ts":"2026-05-28T10:17:39.407Z","level":"INFO","msg":"[POLL] Scheduled [PRD] every 5 min"}
{"ts":"2026-05-28T10:17:43.597Z","level":"WARN","msg":"[POLL] [PRD] Search → HTTP 400"}
{"ts":"2026-05-28T10:17:43.616Z","level":"WARN","msg":"[POLL] [ACC] Search → HTTP 400"}
{"ts":"2026-05-28T10:22:39.637Z","level":"WARN","msg":"[POLL] [PRD] Search → HTTP 400"}
{"ts":"2026-05-28T10:22:39.841Z","level":"WARN","msg":"[POLL] [ACC] Search → HTTP 400"}
{"ts":"2026-05-28T10:27:39.612Z","level":"WARN","msg":"[POLL] [ACC] Search → HTTP 400"}
{"ts":"2026-05-28T10:27:39.824Z","level":"WARN","msg":"[POLL] [PRD] Search → HTTP 400"}
{"ts":"2026-05-28T10:32:39.647Z","level":"WARN","msg":"[POLL] [ACC] Search → HTTP 400"}
{"ts":"2026-05-28T10:32:39.649Z","level":"WARN","msg":"[POLL] [PRD] Search → HTTP 400"}
{"ts":"2026-05-28T10:37:39.849Z","level":"WARN","msg":"[POLL] [ACC] Search → HTTP 400"}
{"ts":"2026-05-28T10:37:40.118Z","level":"WARN","msg":"[POLL] [PRD] Search → HTTP 400"}
{"ts":"2026-05-28T10:42:39.624Z","level":"WARN","msg":"[POLL] [PRD] Search → HTTP 400"}
{"ts":"2026-05-28T10:42:39.638Z","level":"WARN","msg":"[POLL] [ACC] Search → HTTP 400"}