{
  "schema": "webftr-js8lab-daemon-status-v2",
  "version": "step56-message174-crc12-candidate-probe",
  "created_utc": "2026-05-26T07:46:12Z",
  "updated_utc": "2026-05-27T13:15:48Z",
  "state": "diagnostics_ok",
  "detail": "Diagnose fertig",
  "exit_code": 0,
  "root": "/decoders/js8_decoder",
  "expected_root": "/decoders/js8_decoder",
  "wav": "/decoders/js8_test.wav",
  "mode": "message174-crc12-probe",
  "start_guard": {
    "start_stops_existing_instance": true,
    "stale_pid_cleanup": true,
    "root_orphan_cleanup": true,
    "port_guard": true,
    "foreign_port_owner_not_killed": true
  },
  "server": {
    "host": "0.0.0.0",
    "port": 8000,
    "pid": 12413,
    "running": true,
    "log": "/decoders/js8_decoder/logs/js8_browser_server.log"
  },
  "diagnostics": {
    "pid": 12430,
    "running": false,
    "log": "/decoders/js8_decoder/logs/js8_start_diagnostics_latest.log",
    "last_command": "./run_js8_decoder_lab.sh message174-crc12-probe /decoders/js8_test.wav"
  },
  "links": {
    "home": "/",
    "api_report": "/api/report",
    "api_status": "/api/status",
    "logs": "/logs/",
    "latest_log": "/logs/latest.log",
    "start_diagnostics_log": "/logs/js8_start_diagnostics_latest.log",
    "server_log": "/logs/js8_browser_server.log"
  },
  "rx_only_guard": {
    "tx": false,
    "ptt": false,
    "tune": false,
    "send": false,
    "js8call_runtime_control": false
  },
  "history": [
    {
      "utc": "2026-05-27T11:01:27Z",
      "state": "restarting",
      "detail": "Start-Guard: bestehende JS8Lab-Instanz wird geprüft und beendet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:01:27Z",
      "state": "server_starting",
      "detail": "Browser-Logserver startet auf 0.0.0.0:8000",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:01:28Z",
      "state": "server_running",
      "detail": "Browser-Logserver läuft auf 0.0.0.0:8000",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T11:01:28Z",
      "state": "diagnostics_running",
      "detail": "Diagnose läuft: server-deep-run /decoders/js8_test.wav",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:01:28Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 1/9: INPUT CHECK",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:01:29Z",
      "state": "diagnostics_running",
      "detail": "Diagnosejob im Hintergrund gestartet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:01:29Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 2/9A: QUICK WINDOW PREFILTER",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:01:43Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 2/9B: BOUNDED DIRTY WINDOW SCAN",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:02:43Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 3/9: PROFILE SCAN",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:04:09Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 4/9: FRAME RECOVER",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:06:44Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 5/9: AUTO LDPC PROBE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:08:28Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 6/9: CANDIDATE EXPORT",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:08:31Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 7/11: TIMING / BOUNDARY SWEEP",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:11:09Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 8/11: LDPC MATRIX PROBE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:11:12Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 9/11: LDPC SOFT DECODE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:11:22Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 10/13: MESSAGE91 CRC VALIDATION",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:11:26Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 11/13: MESSAGE91 CRC DISTANCE RANKING",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:11:31Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 12/13: MESSAGE91 CRC GUIDED BIT REPAIR",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:12:32Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 13/13: JS8LAB LOG BUNDLE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:12:36Z",
      "state": "diagnostics_ok",
      "detail": "Diagnose fertig",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T11:32:40Z",
      "state": "restarting",
      "detail": "Start-Guard: bestehende JS8Lab-Instanz wird geprüft und beendet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:32:41Z",
      "state": "server_starting",
      "detail": "Browser-Logserver startet auf 0.0.0.0:8000",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:32:42Z",
      "state": "server_running",
      "detail": "Browser-Logserver läuft auf 0.0.0.0:8000",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T11:32:42Z",
      "state": "diagnostics_running",
      "detail": "Diagnose läuft: source-bitpath-audit ",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:32:43Z",
      "state": "diagnostics_running",
      "detail": "Diagnosejob im Hintergrund gestartet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T11:35:43Z",
      "state": "diagnostics_failed",
      "detail": "Diagnose mit Fehler beendet",
      "exit_code": 143
    },
    {
      "utc": "2026-05-27T12:02:39Z",
      "state": "restarting",
      "detail": "Start-Guard: bestehende JS8Lab-Instanz wird geprüft und beendet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:02:39Z",
      "state": "server_starting",
      "detail": "Browser-Logserver startet auf 0.0.0.0:8000",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:02:40Z",
      "state": "server_running",
      "detail": "Browser-Logserver läuft auf 0.0.0.0:8000",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T12:02:40Z",
      "state": "diagnostics_running",
      "detail": "Diagnose läuft: source-bitpath-audit ",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:02:41Z",
      "state": "diagnostics_running",
      "detail": "Diagnosejob im Hintergrund gestartet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:02:46Z",
      "state": "diagnostics_ok",
      "detail": "Diagnose fertig",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T12:47:44Z",
      "state": "restarting",
      "detail": "Start-Guard: bestehende JS8Lab-Instanz wird geprüft und beendet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:47:44Z",
      "state": "server_starting",
      "detail": "Browser-Logserver startet auf 0.0.0.0:8000",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:47:45Z",
      "state": "server_running",
      "detail": "Browser-Logserver läuft auf 0.0.0.0:8000",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T12:47:45Z",
      "state": "diagnostics_running",
      "detail": "Diagnose läuft: source-bitpath-extract ",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:47:46Z",
      "state": "diagnostics_running",
      "detail": "Diagnosejob im Hintergrund gestartet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:47:49Z",
      "state": "diagnostics_ok",
      "detail": "Diagnose fertig",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T12:59:36Z",
      "state": "restarting",
      "detail": "Start-Guard: bestehende JS8Lab-Instanz wird geprüft und beendet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:59:37Z",
      "state": "server_starting",
      "detail": "Browser-Logserver startet auf 0.0.0.0:8000",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:59:38Z",
      "state": "server_running",
      "detail": "Browser-Logserver läuft auf 0.0.0.0:8000",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T12:59:38Z",
      "state": "diagnostics_running",
      "detail": "Diagnose läuft: source-message174-crc12-contract ",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:59:39Z",
      "state": "diagnostics_running",
      "detail": "Diagnosejob im Hintergrund gestartet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T12:59:39Z",
      "state": "diagnostics_ok",
      "detail": "Diagnose fertig",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T13:15:44Z",
      "state": "restarting",
      "detail": "Start-Guard: bestehende JS8Lab-Instanz wird geprüft und beendet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T13:15:44Z",
      "state": "server_starting",
      "detail": "Browser-Logserver startet auf 0.0.0.0:8000",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T13:15:46Z",
      "state": "server_running",
      "detail": "Browser-Logserver läuft auf 0.0.0.0:8000",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T13:15:46Z",
      "state": "diagnostics_running",
      "detail": "Diagnose läuft: message174-crc12-probe /decoders/js8_test.wav",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T13:15:47Z",
      "state": "diagnostics_running",
      "detail": "Diagnosejob im Hintergrund gestartet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T13:15:48Z",
      "state": "diagnostics_ok",
      "detail": "Diagnose fertig",
      "exit_code": 0
    }
  ],
  "status_file": "/decoders/js8_decoder/runtime/js8lab_status.json"
}