{
  "$schema": "runback.audit/v1",
  "manifest": {
    "run_id": "otelmqm4amur",
    "generated_at": "2026-06-20T13:15:06.428Z",
    "event_count": 4,
    "algorithm": "sha256-chain",
    "content_digest": "f3dee9f2d9881e7e3acfd2c2829e2867799ef75ee741b44883d1aca1a9415b61",
    "signed": true,
    "signature": {
      "alg": "HMAC-SHA256",
      "value": "aede3e906d0711a2ca75f661a9d4e56134c855f433d8b5f526c9e0a82ac84d8a"
    },
    "verify": "Recompute h_i = SHA-256(h_{i-1} + canonical(event_i)) over `events` (strip _hash, sort keys). The final hash must equal manifest.content_digest, and each event._hash must match its step. POST this record to /api/audit/verify to check automatically."
  },
  "run": {
    "run_id": "otelmqm4amur",
    "name": "research-agent",
    "status": "success",
    "input": "Summarize Next.js 16",
    "output": null,
    "error": null,
    "metadata": {
      "source": "otel",
      "trace_id": "otelmqm4amur"
    },
    "step_count": 1,
    "total_tokens": 160,
    "started_at": "1970-01-01T00:00:01+00:00",
    "ended_at": "1970-01-01T00:00:02.2+00:00"
  },
  "events": [
    {
      "seq": 0,
      "name": "research-agent",
      "type": "run",
      "error": null,
      "input": "Summarize Next.js 16",
      "phase": "start",
      "output": null,
      "run_id": "otelmqm4amur",
      "status": "running",
      "ts_end": null,
      "span_id": "run:otelmqm4amur",
      "metadata": {
        "source": "otel",
        "trace_id": "otelmqm4amur"
      },
      "ts_start": "1970-01-01T00:00:01.000Z",
      "parent_span_id": null,
      "schema_version": 1,
      "_hash": "71163dc7c05e69051756474cbe23bde979d03a540af82a2c00056ca396905918"
    },
    {
      "seq": 1,
      "type": "llm",
      "error": null,
      "model": {
        "model_id": "gpt-4o",
        "provider": "openai"
      },
      "usage": {
        "input_tokens": 120,
        "total_tokens": 160,
        "output_tokens": 40
      },
      "run_id": "otelmqm4amur",
      "ts_end": "1970-01-01T00:00:02.800Z",
      "request": {
        "tools": [],
        "params": {},
        "system": "You are a research assistant.",
        "messages": [
          {
            "role": "user",
            "content": "Summarize Next.js 16"
          }
        ]
      },
      "span_id": "llm1",
      "response": {
        "text": "Next.js 16 ships async params and Turbopack by default.",
        "reasoning": null,
        "tool_calls": [],
        "finish_reason": "stop"
      },
      "ts_start": "1970-01-01T00:00:02.000Z",
      "latency_ms": 800,
      "parent_span_id": "run:otelmqm4amur",
      "schema_version": 1,
      "_hash": "d00cce1c6d810e47a3921ce8f8763646845d5e52b773942b5591cabeb4ceadb1"
    },
    {
      "seq": 2,
      "type": "tool",
      "error": null,
      "input": {
        "query": "Next.js 16"
      },
      "output": {
        "hits": 3
      },
      "run_id": "otelmqm4amur",
      "ts_end": "1970-01-01T00:00:02.200Z",
      "span_id": "tool1",
      "ts_start": "1970-01-01T00:00:02.100Z",
      "tool_name": "web_search",
      "latency_ms": 100,
      "tool_call_id": "",
      "parent_span_id": "run:otelmqm4amur",
      "schema_version": 1,
      "_hash": "65d61e98e96514528ed465996af1b6adc59a0e39449700456db3a28754f25ee6"
    },
    {
      "seq": 3,
      "name": "research-agent",
      "type": "run",
      "error": null,
      "input": null,
      "phase": "end",
      "output": null,
      "run_id": "otelmqm4amur",
      "status": "success",
      "ts_end": "1970-01-01T00:00:02.200Z",
      "span_id": "run:otelmqm4amur~end",
      "metadata": {},
      "ts_start": "1970-01-01T00:00:02.200Z",
      "parent_span_id": "run:otelmqm4amur",
      "schema_version": 1,
      "_hash": "f3dee9f2d9881e7e3acfd2c2829e2867799ef75ee741b44883d1aca1a9415b61"
    }
  ]
}