{
  "schema": "webftr-js8lab-daemon-status-v2",
  "version": "step38-fine-timing-ridge-sweep",
  "created_utc": "2026-05-26T07:46:12Z",
  "updated_utc": "2026-05-27T04:27:15Z",
  "state": "diagnostics_running",
  "detail": "REAL-RUN STEP 9/10: LDPC SOFT DECODE",
  "exit_code": null,
  "root": "/decoders/js8_decoder",
  "expected_root": "/decoders/js8_decoder",
  "wav": "/decoders/js8_test.wav",
  "mode": "server-deep-run",
  "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": 595102,
    "running": true,
    "log": "/decoders/js8_decoder/logs/js8_browser_server.log"
  },
  "diagnostics": {
    "pid": 595118,
    "running": true,
    "log": "/decoders/js8_decoder/logs/js8_start_diagnostics_latest.log",
    "last_command": "./run_js8_decoder_lab.sh server-deep-run /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-26T18:17:40Z",
      "state": "diagnostics_failed",
      "detail": "Diagnose mit Fehler beendet",
      "exit_code": 143
    },
    {
      "utc": "2026-05-27T03:35:12Z",
      "state": "restarting",
      "detail": "Start-Guard: bestehende JS8Lab-Instanz wird geprüft und beendet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:35:13Z",
      "state": "server_starting",
      "detail": "Browser-Logserver startet auf 0.0.0.0:8000",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:35:14Z",
      "state": "server_running",
      "detail": "Browser-Logserver läuft auf 0.0.0.0:8000",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T03:35:14Z",
      "state": "diagnostics_running",
      "detail": "Diagnose läuft: server-deep-run /decoders/js8_test.wav",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:35:14Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 1/9: INPUT CHECK",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:35:15Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 2/9A: QUICK WINDOW PREFILTER",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:35:15Z",
      "state": "diagnostics_running",
      "detail": "Diagnosejob im Hintergrund gestartet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:35:29Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 2/9B: BOUNDED DIRTY WINDOW SCAN",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:36:29Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 3/9: PROFILE SCAN",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:38:02Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 4/9: FRAME RECOVER",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:40:31Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 5/9: AUTO LDPC PROBE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:42:16Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 6/9: CANDIDATE EXPORT",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:42:18Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 7/10: TIMING / BOUNDARY SWEEP",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:43:31Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 8/10: LDPC MATRIX PROBE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:43:34Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 9/10: LDPC SOFT DECODE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:44:19Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 10/10: JS8LAB LOG BUNDLE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:44:21Z",
      "state": "diagnostics_ok",
      "detail": "Diagnose fertig",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T03:56:32Z",
      "state": "restarting",
      "detail": "Start-Guard: bestehende JS8Lab-Instanz wird geprüft und beendet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:56:33Z",
      "state": "server_starting",
      "detail": "Browser-Logserver startet auf 0.0.0.0:8000",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:56:34Z",
      "state": "server_running",
      "detail": "Browser-Logserver läuft auf 0.0.0.0:8000",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T03:56:34Z",
      "state": "diagnostics_running",
      "detail": "Diagnose läuft: server-deep-run /decoders/js8_test.wav",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:56:34Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 1/9: INPUT CHECK",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:56:35Z",
      "state": "diagnostics_running",
      "detail": "Diagnosejob im Hintergrund gestartet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:56:35Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 2/9A: QUICK WINDOW PREFILTER",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:56:48Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 2/9B: BOUNDED DIRTY WINDOW SCAN",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:57:49Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 3/9: PROFILE SCAN",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T03:59:13Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 4/9: FRAME RECOVER",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:01:44Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 5/9: AUTO LDPC PROBE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:03:31Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 6/9: CANDIDATE EXPORT",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:03:33Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 7/10: TIMING / BOUNDARY SWEEP",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:05:19Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 8/10: LDPC MATRIX PROBE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:05:22Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 9/10: LDPC SOFT DECODE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:06:07Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 10/10: JS8LAB LOG BUNDLE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:06:09Z",
      "state": "diagnostics_ok",
      "detail": "Diagnose fertig",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T04:18:21Z",
      "state": "restarting",
      "detail": "Start-Guard: bestehende JS8Lab-Instanz wird geprüft und beendet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:18:21Z",
      "state": "server_starting",
      "detail": "Browser-Logserver startet auf 0.0.0.0:8000",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:18:23Z",
      "state": "server_running",
      "detail": "Browser-Logserver läuft auf 0.0.0.0:8000",
      "exit_code": 0
    },
    {
      "utc": "2026-05-27T04:18:23Z",
      "state": "diagnostics_running",
      "detail": "Diagnose läuft: server-deep-run /decoders/js8_test.wav",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:18:23Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 1/9: INPUT CHECK",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:18:24Z",
      "state": "diagnostics_running",
      "detail": "Diagnosejob im Hintergrund gestartet",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:18:24Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 2/9A: QUICK WINDOW PREFILTER",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:18:37Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 2/9B: BOUNDED DIRTY WINDOW SCAN",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:19:37Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 3/9: PROFILE SCAN",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:21:01Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 4/9: FRAME RECOVER",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:23:39Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 5/9: AUTO LDPC PROBE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:25:24Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 6/9: CANDIDATE EXPORT",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:25:26Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 7/10: TIMING / BOUNDARY SWEEP",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:27:12Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 8/10: LDPC MATRIX PROBE",
      "exit_code": null
    },
    {
      "utc": "2026-05-27T04:27:15Z",
      "state": "diagnostics_running",
      "detail": "REAL-RUN STEP 9/10: LDPC SOFT DECODE",
      "exit_code": null
    }
  ],
  "status_file": "/decoders/js8_decoder/runtime/js8lab_status.json"
}