{
  "schemaVersion": "1.0",
  "item": {
    "slug": "auto-drive-jim",
    "name": "Auto Drive",
    "source": "tencent",
    "type": "skill",
    "category": "效率提升",
    "sourceUrl": "https://clawhub.ai/jim-counter/auto-drive-jim",
    "canonicalUrl": "https://clawhub.ai/jim-counter/auto-drive-jim",
    "targetPlatform": "OpenClaw"
  },
  "install": {
    "downloadMode": "redirect",
    "downloadUrl": "/downloads/auto-drive-jim",
    "sourceDownloadUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=auto-drive-jim",
    "sourcePlatform": "tencent",
    "targetPlatform": "OpenClaw",
    "installMethod": "Manual import",
    "extraction": "Extract archive",
    "prerequisites": [
      "OpenClaw"
    ],
    "packageFormat": "ZIP package",
    "includedAssets": [
      "SKILL.md",
      "scripts/verify-setup.sh",
      "scripts/autodrive-upload.sh",
      "scripts/autodrive-download.sh",
      "scripts/autodrive-save-memory.sh",
      "scripts/setup-auto-drive.sh"
    ],
    "primaryDoc": "SKILL.md",
    "quickSetup": [
      "Download the package from Yavira.",
      "Extract the archive and review SKILL.md first.",
      "Import or place the package into your OpenClaw setup."
    ],
    "agentAssist": {
      "summary": "Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.",
      "steps": [
        "Download the package from Yavira.",
        "Extract it into a folder your agent can access.",
        "Paste one of the prompts below and point your agent at the extracted folder."
      ],
      "prompts": [
        {
          "label": "New install",
          "body": "I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete."
        },
        {
          "label": "Upgrade existing",
          "body": "I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run."
        }
      ]
    },
    "sourceHealth": {
      "source": "tencent",
      "status": "healthy",
      "reason": "direct_download_ok",
      "recommendedAction": "download",
      "checkedAt": "2026-04-23T16:43:11.935Z",
      "expiresAt": "2026-04-30T16:43:11.935Z",
      "httpStatus": 200,
      "finalUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=4claw-imageboard",
      "contentType": "application/zip",
      "probeMethod": "head",
      "details": {
        "probeUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=4claw-imageboard",
        "contentDisposition": "attachment; filename=\"4claw-imageboard-1.0.1.zip\"",
        "redirectLocation": null,
        "bodySnippet": null
      },
      "scope": "source",
      "summary": "Source download looks usable.",
      "detail": "Yavira can redirect you to the upstream package for this source.",
      "primaryActionLabel": "Download for OpenClaw",
      "primaryActionHref": "/downloads/auto-drive-jim"
    },
    "validation": {
      "installChecklist": [
        "Use the Yavira download entry.",
        "Review SKILL.md after the package is downloaded.",
        "Confirm the extracted package contains the expected setup assets."
      ],
      "postInstallChecks": [
        "Confirm the extracted package includes the expected docs or setup files.",
        "Validate the skill or prompts are available in your target agent workspace.",
        "Capture any manual follow-up steps the agent could not complete."
      ]
    },
    "downloadPageUrl": "https://openagent3.xyz/downloads/auto-drive-jim",
    "agentPageUrl": "https://openagent3.xyz/skills/auto-drive-jim/agent",
    "manifestUrl": "https://openagent3.xyz/skills/auto-drive-jim/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/auto-drive-jim/agent.md"
  },
  "agentAssist": {
    "summary": "Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.",
    "steps": [
      "Download the package from Yavira.",
      "Extract it into a folder your agent can access.",
      "Paste one of the prompts below and point your agent at the extracted folder."
    ],
    "prompts": [
      {
        "label": "New install",
        "body": "I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete."
      },
      {
        "label": "Upgrade existing",
        "body": "I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run."
      }
    ]
  },
  "documentation": {
    "source": "clawhub",
    "primaryDoc": "SKILL.md",
    "sections": [
      {
        "title": "Auto-Drive Skill",
        "body": "Permanent decentralized storage on the Autonomys Network with linked-list memory chains for agent resurrection."
      },
      {
        "title": "What This Skill Does",
        "body": "Upload files to Auto-Drive and get back a CID (Content Identifier) — a permanent, immutable address on the Autonomys distributed storage network.\nDownload files from Auto-Drive using a CID — uses the authenticated API if a key is set, otherwise falls back to the public gateway.\nSave memories as a chain — each memory entry is a JSON experience with a header.previousCid pointer, forming a linked list stored permanently on-chain.\nResurrect from a chain — given the latest CID, walk the chain backwards to reconstruct full agent history."
      },
      {
        "title": "When To Use This Skill",
        "body": "User says \"save this to Auto-Drive\" or \"upload to Autonomys\" or \"store permanently\"\nUser says \"download from Auto-Drive\" or provides a CID to retrieve\nUser says \"save memory\", \"remember this permanently\", or \"checkpoint\"\nUser says \"resurrect\", \"recall chain\", \"rebuild memory\", or \"load history\"\nAny time the user wants data stored permanently and immutably on a decentralized network"
      },
      {
        "title": "API Key",
        "body": "Requires an AUTO_DRIVE_API_KEY. Run the guided setup script for the easiest path:\n\nscripts/setup-auto-drive.sh\n\nThis opens explorer.ai3.storage in your browser, prompts for the key, saves it to ~/.openclaw/.env, and verifies the connection.\n\nManual setup:\n\nNavigate to https://explorer.ai3.storage (not ai3.storage — that's just the landing page)\nCheck authentication: if the sidebar shows a \"Log In\" button or lock icons on My Files / Profile / Developers, you are not signed in\nAI agent note: You cannot complete OAuth yourself. Open the browser for the user and ask them to sign in via Google, GitHub, or Discord. Once the user confirms they're signed in, take over — or simply ask the user to paste the API key directly\nOnce authenticated, click Developers in the left sidebar\nClick Create API Key and copy the generated key\n\nThen set the key via:\n\nEnvironment: export AUTO_DRIVE_API_KEY=your_key_here\nOpenClaw config: skills.entries.auto-drive.apiKey\n\nThe API key is required for uploading, saving memories, and recalling the memory chain. It is optional for general file downloads — without it, the public gateway is used and files are returned as stored (i.e. compressed files will not be decompressed)."
      },
      {
        "title": "Upload a File",
        "body": "scripts/autodrive-upload.sh <filepath> [--json] [--compress]\n\nUploads a file to Auto-Drive mainnet using the 3-step upload protocol (single chunk).\nReturns the CID on stdout. Requires AUTO_DRIVE_API_KEY.\n\n--json — force MIME type to application/json\n--compress — enable ZLIB compression"
      },
      {
        "title": "Download a File",
        "body": "scripts/autodrive-download.sh <cid> [output_path]\n\nDownloads a file by CID. Uses the authenticated API if AUTO_DRIVE_API_KEY is set (decompresses server-side), otherwise uses the public gateway (files returned as stored). If output_path is omitted, outputs to stdout."
      },
      {
        "title": "Save a Memory Entry",
        "body": "scripts/autodrive-save-memory.sh <data_file_or_string> [--agent-name NAME] [--state-file PATH]\n\nCreates a memory experience with the Autonomys Agents header/data structure:\n\n{\n  \"header\": {\n    \"agentName\": \"my-agent\",\n    \"agentVersion\": \"1.0.0\",\n    \"timestamp\": \"2026-02-14T00:00:00.000Z\",\n    \"previousCid\": \"bafk...or null\"\n  },\n  \"data\": {\n    \"type\": \"memory\",\n    \"content\": \"...\"\n  }\n}\n\nIf the first argument is a file path, its JSON contents become the data payload.\nIf the first argument is a plain string, it is wrapped as {\"type\": \"memory\", \"content\": \"...\"}.\n--agent-name — set the agent name in the header (default: openclaw-agent or $AGENT_NAME)\n--state-file — override the state file location\n\nUploads to Auto-Drive and updates the state file with the new head CID. Also pins the latest CID to MEMORY.md if that file exists in the workspace.\n\nReturns structured JSON on stdout:\n\n{\"cid\": \"bafk...\", \"previousCid\": \"bafk...\", \"chainLength\": 5}"
      },
      {
        "title": "Recall the Full Chain",
        "body": "scripts/autodrive-recall-chain.sh [cid] [--limit N] [--output-dir DIR]\n\nIf no CID is given, reads the latest CID from the state file.\nWalks the linked list from newest to oldest, outputting each experience as JSON.\n\n--limit N — maximum entries to retrieve (default: 50)\n--output-dir DIR — save each entry as a numbered JSON file instead of printing to stdout\n\nSupports both header.previousCid (Autonomys Agents format) and root-level previousCid for backward compatibility.\n\nThis is the resurrection mechanism: a new agent instance only needs one CID to rebuild its entire memory."
      },
      {
        "title": "The Resurrection Concept",
        "body": "Every memory saved gets a unique CID and points back to the previous one:\n\nExperience #3 (CID: bafk...xyz)\n  → header.previousCid: bafk...def (Experience #2)\n    → header.previousCid: bafk...abc (Experience #1)\n      → header.previousCid: null (genesis)\n\nIf the agent's server dies, a new instance only needs the last CID to walk the entire chain and reconstruct full context. It's version control for consciousness, stored permanently on the Autonomys Network."
      },
      {
        "title": "Usage Examples",
        "body": "User: \"Upload my report to Auto-Drive\"\n→ Run scripts/autodrive-upload.sh /path/to/report.pdf\n→ Report back the CID and gateway link\n\nUser: \"Upload with compression\"\n→ Run scripts/autodrive-upload.sh /path/to/data.json --json --compress\n\nUser: \"Save a memory that we decided to use React for the frontend\"\n→ Run scripts/autodrive-save-memory.sh \"Decision: using React for frontend. Reason: team familiarity and component reuse.\"\n\nUser: \"Save a structured memory\"\n→ Create a JSON file, then run scripts/autodrive-save-memory.sh /tmp/milestone.json --agent-name my-agent\n\nUser: \"Resurrect my memory chain\"\n→ Run scripts/autodrive-recall-chain.sh\n→ Display the full history from genesis to present\n\nUser: \"Download bafk...abc from Autonomys\"\n→ Run scripts/autodrive-download.sh bafk...abc ./downloaded_file"
      },
      {
        "title": "Important Notes",
        "body": "All data stored on Auto-Drive is permanent and public by default. Do not store secrets, private keys, or sensitive personal data.\nThe free API key has a 20 MB per month upload limit on mainnet. Downloads are unlimited. Check remaining credits via GET /accounts/@me or run scripts/verify-setup.sh.\nAn API key is required for uploads, memory saves, and chain recall. General file downloads work without one via the public gateway, but compressed files will not be decompressed.\nThe memory state file tracks lastCid, lastUploadTimestamp, and chainLength. Back up the lastCid value — it's your resurrection key.\nThe autodrive-save-memory.sh script automatically pins the latest CID to MEMORY.md if the file exists in the workspace. It creates an ## Auto-Drive Chain section and updates it on each save. You do not need to track the latest CID in MEMORY.md manually — the script handles this.\nFiles are uploaded in a single chunk. The free tier's 20 MB/month limit is effectively a per-file ceiling — keep individual uploads well under that to preserve your monthly budget.\nGateway URL for any file: https://gateway.autonomys.xyz/file/<CID>\nFor true resurrection resilience, consider anchoring the latest CID on-chain via the Autonomys EVM — this makes recovery possible without keeping track of the head CID yourself. See openclaw-memory-chain for an example contract implementation."
      }
    ],
    "body": "Auto-Drive Skill\n\nPermanent decentralized storage on the Autonomys Network with linked-list memory chains for agent resurrection.\n\nWhat This Skill Does\nUpload files to Auto-Drive and get back a CID (Content Identifier) — a permanent, immutable address on the Autonomys distributed storage network.\nDownload files from Auto-Drive using a CID — uses the authenticated API if a key is set, otherwise falls back to the public gateway.\nSave memories as a chain — each memory entry is a JSON experience with a header.previousCid pointer, forming a linked list stored permanently on-chain.\nResurrect from a chain — given the latest CID, walk the chain backwards to reconstruct full agent history.\nWhen To Use This Skill\nUser says \"save this to Auto-Drive\" or \"upload to Autonomys\" or \"store permanently\"\nUser says \"download from Auto-Drive\" or provides a CID to retrieve\nUser says \"save memory\", \"remember this permanently\", or \"checkpoint\"\nUser says \"resurrect\", \"recall chain\", \"rebuild memory\", or \"load history\"\nAny time the user wants data stored permanently and immutably on a decentralized network\nConfiguration\nAPI Key\n\nRequires an AUTO_DRIVE_API_KEY. Run the guided setup script for the easiest path:\n\nscripts/setup-auto-drive.sh\n\n\nThis opens explorer.ai3.storage in your browser, prompts for the key, saves it to ~/.openclaw/.env, and verifies the connection.\n\nManual setup:\n\nNavigate to https://explorer.ai3.storage (not ai3.storage — that's just the landing page)\nCheck authentication: if the sidebar shows a \"Log In\" button or lock icons on My Files / Profile / Developers, you are not signed in\nAI agent note: You cannot complete OAuth yourself. Open the browser for the user and ask them to sign in via Google, GitHub, or Discord. Once the user confirms they're signed in, take over — or simply ask the user to paste the API key directly\nOnce authenticated, click Developers in the left sidebar\nClick Create API Key and copy the generated key\n\nThen set the key via:\n\nEnvironment: export AUTO_DRIVE_API_KEY=your_key_here\nOpenClaw config: skills.entries.auto-drive.apiKey\n\nThe API key is required for uploading, saving memories, and recalling the memory chain. It is optional for general file downloads — without it, the public gateway is used and files are returned as stored (i.e. compressed files will not be decompressed).\n\nCore Operations\nUpload a File\nscripts/autodrive-upload.sh <filepath> [--json] [--compress]\n\n\nUploads a file to Auto-Drive mainnet using the 3-step upload protocol (single chunk). Returns the CID on stdout. Requires AUTO_DRIVE_API_KEY.\n\n--json — force MIME type to application/json\n--compress — enable ZLIB compression\nDownload a File\nscripts/autodrive-download.sh <cid> [output_path]\n\n\nDownloads a file by CID. Uses the authenticated API if AUTO_DRIVE_API_KEY is set (decompresses server-side), otherwise uses the public gateway (files returned as stored). If output_path is omitted, outputs to stdout.\n\nSave a Memory Entry\nscripts/autodrive-save-memory.sh <data_file_or_string> [--agent-name NAME] [--state-file PATH]\n\n\nCreates a memory experience with the Autonomys Agents header/data structure:\n\n{\n  \"header\": {\n    \"agentName\": \"my-agent\",\n    \"agentVersion\": \"1.0.0\",\n    \"timestamp\": \"2026-02-14T00:00:00.000Z\",\n    \"previousCid\": \"bafk...or null\"\n  },\n  \"data\": {\n    \"type\": \"memory\",\n    \"content\": \"...\"\n  }\n}\n\nIf the first argument is a file path, its JSON contents become the data payload.\nIf the first argument is a plain string, it is wrapped as {\"type\": \"memory\", \"content\": \"...\"}.\n--agent-name — set the agent name in the header (default: openclaw-agent or $AGENT_NAME)\n--state-file — override the state file location\n\nUploads to Auto-Drive and updates the state file with the new head CID. Also pins the latest CID to MEMORY.md if that file exists in the workspace.\n\nReturns structured JSON on stdout:\n\n{\"cid\": \"bafk...\", \"previousCid\": \"bafk...\", \"chainLength\": 5}\n\nRecall the Full Chain\nscripts/autodrive-recall-chain.sh [cid] [--limit N] [--output-dir DIR]\n\n\nIf no CID is given, reads the latest CID from the state file. Walks the linked list from newest to oldest, outputting each experience as JSON.\n\n--limit N — maximum entries to retrieve (default: 50)\n--output-dir DIR — save each entry as a numbered JSON file instead of printing to stdout\n\nSupports both header.previousCid (Autonomys Agents format) and root-level previousCid for backward compatibility.\n\nThis is the resurrection mechanism: a new agent instance only needs one CID to rebuild its entire memory.\n\nThe Resurrection Concept\n\nEvery memory saved gets a unique CID and points back to the previous one:\n\nExperience #3 (CID: bafk...xyz)\n  → header.previousCid: bafk...def (Experience #2)\n    → header.previousCid: bafk...abc (Experience #1)\n      → header.previousCid: null (genesis)\n\n\nIf the agent's server dies, a new instance only needs the last CID to walk the entire chain and reconstruct full context. It's version control for consciousness, stored permanently on the Autonomys Network.\n\nUsage Examples\n\nUser: \"Upload my report to Auto-Drive\" → Run scripts/autodrive-upload.sh /path/to/report.pdf → Report back the CID and gateway link\n\nUser: \"Upload with compression\" → Run scripts/autodrive-upload.sh /path/to/data.json --json --compress\n\nUser: \"Save a memory that we decided to use React for the frontend\" → Run scripts/autodrive-save-memory.sh \"Decision: using React for frontend. Reason: team familiarity and component reuse.\"\n\nUser: \"Save a structured memory\" → Create a JSON file, then run scripts/autodrive-save-memory.sh /tmp/milestone.json --agent-name my-agent\n\nUser: \"Resurrect my memory chain\" → Run scripts/autodrive-recall-chain.sh → Display the full history from genesis to present\n\nUser: \"Download bafk...abc from Autonomys\" → Run scripts/autodrive-download.sh bafk...abc ./downloaded_file\n\nImportant Notes\nAll data stored on Auto-Drive is permanent and public by default. Do not store secrets, private keys, or sensitive personal data.\nThe free API key has a 20 MB per month upload limit on mainnet. Downloads are unlimited. Check remaining credits via GET /accounts/@me or run scripts/verify-setup.sh.\nAn API key is required for uploads, memory saves, and chain recall. General file downloads work without one via the public gateway, but compressed files will not be decompressed.\nThe memory state file tracks lastCid, lastUploadTimestamp, and chainLength. Back up the lastCid value — it's your resurrection key.\nThe autodrive-save-memory.sh script automatically pins the latest CID to MEMORY.md if the file exists in the workspace. It creates an ## Auto-Drive Chain section and updates it on each save. You do not need to track the latest CID in MEMORY.md manually — the script handles this.\nFiles are uploaded in a single chunk. The free tier's 20 MB/month limit is effectively a per-file ceiling — keep individual uploads well under that to preserve your monthly budget.\nGateway URL for any file: https://gateway.autonomys.xyz/file/<CID>\nFor true resurrection resilience, consider anchoring the latest CID on-chain via the Autonomys EVM — this makes recovery possible without keeping track of the head CID yourself. See openclaw-memory-chain for an example contract implementation."
  },
  "trust": {
    "sourceLabel": "tencent",
    "provenanceUrl": "https://clawhub.ai/jim-counter/auto-drive-jim",
    "publisherUrl": "https://clawhub.ai/jim-counter/auto-drive-jim",
    "owner": "jim-counter",
    "version": "1.0.0",
    "license": null,
    "verificationStatus": "Indexed source record"
  },
  "links": {
    "detailUrl": "https://openagent3.xyz/skills/auto-drive-jim",
    "downloadUrl": "https://openagent3.xyz/downloads/auto-drive-jim",
    "agentUrl": "https://openagent3.xyz/skills/auto-drive-jim/agent",
    "manifestUrl": "https://openagent3.xyz/skills/auto-drive-jim/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/auto-drive-jim/agent.md"
  }
}