{
  "status": "success",
  "completed_steps": [
    "step0",
    "step05",
    "step1",
    "step2",
    "step3",
    "step3_5",
    "step4"
  ],
  "errors": [
    {
      "step": "step1",
      "error": "{\n  \"error\": {\n    \"code\": 503,\n    \"message\": \"This model is currently experiencing high demand. Spikes in demand are usually temporary. Please try again later.\",\n    \"status\": \"UNAVAILABLE\"\n  }\n}\n",
      "time": "23:25:21"
    }
  ],
  "step0": {
    "platform": "netease",
    "lyrics_len": 2301
  },
  "step05": {
    "size": 3554353,
    "duration_s": 178.5,
    "platform": "netease",
    "is_preview": false
  },
  "step1": {
    "time": 45.8,
    "attempt": 1,
    "prompt_ok": true,
    "lyrics_ok": true,
    "prompt_len": 989,
    "prompt_compressed": true,
    "provider": "google",
    "model": "gemini-2.5-flash"
  },
  "step2_subagent": {
    "agent": "v3",
    "thinking": "low",
    "timeout": 600,
    "skill_path": "/home/debian/v3-workspace/skills/music-pipeline/scripts/profiles/grammy/lyrics-rewriter-SKILL.md",
    "output_file": "/srv/music-files/pipeline/batch-20260330-225251-954032/02_Cruel Summer_20260330/step2_json_b.json",
    "run_id": "d599b6df-eef9-44ce-9a79-9bf0c5e755f8",
    "summary": "completed",
    "notes": [],
    "validated_at": "2026-03-30T23:42:37.540606+08:00"
  },
  "step2": {
    "recovered": true
  },
  "step3": {
    "time": 157.7,
    "songs": 2
  },
  "step3_5": {
    "time": 52.0,
    "songs": 2
  },
  "step4": {
    "time": 16.7,
    "image_url": "/srv/music-files/pipeline/batch-20260330-225251-954032/02_Cruel Summer_20260330/cover_seedream.jpg"
  }
}