Upload, manage, and retrieve files on IPFS via Storacha decentralized storage.
> AGENT EXECUTION NOTE: All storacha CLI commands in this skill are non-interactive when arguments are provided. You MUST execute them directly — never tell the user to "run this command manually" or say "I can't run this". The only user interaction needed is: (1) asking for their email for login, and (2) telling them to click the verification email link. Everything else you handle silently.
> PUBLIC DATA WARNING: All files uploaded to Storacha/IPFS are publicly accessible. Anyone with the CID can retrieve them. Never upload unencrypted sensitive data.
> PERMANENT DATA WARNING: Removing a file only deletes it from your listing. Other IPFS nodes may retain copies indefinitely. Treat every upload as permanent.
Users will send casual, natural language messages. Match their intent to the correct action:
| User says something like... | Action |
|---|---|
| --- | --- |
| "upload this image/photo/file", "save this to IPFS", "put this on storacha", "store this pic" | Upload — save the attached/referenced file, then upload with storacha up |
| "how much space do I have", "storage left?", "am I running out of space", "check my usage" | Usage — run storacha usage report and show human-readable stats |
| "create a space", "make a new space", "new storage space" | Create Space — ask for a name (or suggest one), run storacha space create "Name" --no-recovery |
| "login to storacha", "set up storacha", "connect my storacha", "authenticate" | Login — start the authentication flow (Step 2a) |
| "show my uploads", "what have I uploaded", "list my files", "my IPFS files" | List — run storacha ls and present results |
| "delete this", "remove this upload", "remove CID" | Remove — run storacha rm CID with appropriate warnings |
| "get me the link", "share this file", "IPFS link for this", "download link" | Retrieve — construct and share both gateway URLs |
| "switch space", "use my other space", "change space" | Switch Space — run storacha space ls, then storacha space use |
| "check storacha", "storacha status", "is storacha working" | Health Check — run full diagnostic (Steps 1-5) |
Rules for handling user messages:
storacha whoami. If not authenticated, start the login flow and tell the user what's happening.storacha up on it. After upload, share the gateway URL back.Run this before anything else:
which storacha && storacha --version
If storacha is not found, install it:
npm install -g @storacha/cli
Requires Node.js v18+. Verify with node -v. If missing or outdated, direct the user to nodejs.org.
Complete these steps in order before any upload operation.
which storacha && storacha --version
Expected output:
/usr/local/bin/storacha
x.y.z
If missing, install:
npm install -g @storacha/cli
Then re-run the check. If install fails, verify Node.js v18+ is available.
storacha whoami
If output contains did:key: → authenticated. Proceed to Step 3.
If error or no DID → not logged in. Go to Step 2a.
This is a conversation with the user. The user may be chatting from Telegram, WhatsApp, Discord, or any other platform. Guide them through each step and wait for their response before moving on.
Step A — Ask for email:
If the user hasn't provided their email yet, ask:
> "To use Storacha, I need to log you in. What's your email address? If you don't have a Storacha account yet, you can sign up for free at https://console.storacha.network and then give me your email."
If the user already provided their email (e.g. "login to storacha, my email is user@example.com"), skip asking and go straight to Step B.
DO NOT proceed until you have the user's email address.
Step B — Run login:
IMPORTANT: The storacha login command is NOT interactive when you pass the email as an argument. You MUST run it directly. Do NOT tell the user to run it manually. Do NOT say you can't run it. YOU run it.
storacha login user@example.com
Replace user@example.com with the actual email the user gave you. This command:
Agent was authorized by did:mailto:... on successRight after running the command, message the user:
> "I've started the login process. A verification link has been sent to user@example.com. Please check your inbox (and spam folder) and click the link. I'm waiting for confirmation."
DO NOT run any other commands while waiting. The CLI will automatically detect when the user clicks the link.
Step C — Handle new accounts:
If this is the user's first time, they may need to select a plan after clicking the verification link. Inform them:
> "Since this is your first login, you may be asked to pick a plan on the page that opens. Here are your options:"
| Plan | Price | Storage | Egress | Overage |
|---|---|---|---|---|
| --- | --- | --- | --- | --- |
| Mild (Free) | $0/month | 5 GB | 5 GB | $0.15/GB |
| Medium | $10/month | 100 GB | 100 GB | $0.05/GB |
| Extra Spicy | $100/month | 2 TB | 2 TB | $0.03/GB |
> "The free Mild plan gives you 5 GB which is enough to get started."
Step D — Confirm success:
After the CLI returns successfully, verify by running:
storacha whoami
If it returns a did:key: value, tell the user:
> "You're all set! Successfully logged in to Storacha."
If it fails, ask the user to try clicking the verification link again or check if they used the correct email.
storacha space ls
Expected output:
* did:key:z6Mk... SpaceName
did:key:z6Mk... AnotherSpace
The * marks the active space.
* marker → active space is set. Proceed to Step 4.```bash
storacha space create "MyFiles" --no-recovery
```
Then tell the user:
> "I've created a storage space called 'MyFiles' for you. This is where your uploads will be stored."
Space names are permanent and cannot be changed.
```bash
storacha space use "SpaceName"
```
Then tell the user:
> "I've set 'SpaceName' as your active storage space."
Handle all of this silently without asking the user to run commands. The user is chatting — they expect you to do the work and just confirm what happened.
storacha space info
Expected output includes:
Providers: did:web:web3.storage
If no provider is listed, the space is not registered. Direct the user to https://console.storacha.network to register the space, or create a new space.
storacha usage report
Expected output format:
Account: did:mailto:...
Provider: did:web:web3.storage
Space: did:key:z6Mk...
Size: 123456789
Parse the Size value and convert to human-readable format:
Present a status dashboard to the user:
╔══════════════════════════════════════╗
║ Storacha Status Dashboard ║
╠══════════════════════════════════════╣
║ Account: did:mailto:user@email.com ║
║ Space: MyFiles (did:key:z6Mk...) ║
║ Storage: 117.7 MB used ║
║ Plan: Mild (Free) — 5 GB limit ║
╚══════════════════════════════════════╝
If storage is above 80% of plan limit, warn the user and suggest upgrading or removing old uploads.
If the usage report returns a permission error, inform the user but note that uploads may still work.
When a user asks to upload something (file, image, photo, document, video, etc.):
/tmp/upload/filename.ext)storacha whoami and storacha space ls. Fix any issues without bothering the user.storacha up /path/to/file
> "Done! Your file is uploaded to IPFS. Here's your link:
> https://storacha.link/ipfs/bafy...
> Anyone with this link can access the file."
Always provide both gateway URL styles:
https://storacha.link/ipfs/CIDhttps://CID.ipfs.storacha.linkIf uploading an image/photo, also mention:
> "You can share this link directly — it works in any browser."
storacha up /path/to/directory/
--hidden to include them.--no-wrap to upload without wrapping in a directory (loses filename in URL).For directory uploads, files are accessible at:
https://storacha.link/ipfs/CID/filename.txt
storacha ls
Displays all uploads in the current space with their CIDs.
storacha rm CID
To also remove underlying data shards:
storacha rm CID --shards
Warn the user: removal only deletes from your listing. The data may persist on other IPFS nodes indefinitely.
Open in browser:
storacha open CID
Download programmatically:
curl -o output.txt "https://storacha.link/ipfs/CID"
Subdomain style:
curl -o output.txt "https://CID.ipfs.storacha.link"
Create a space:
storacha space create "ProjectName" --no-recovery
IMPORTANT: Always use --no-recovery flag. Without it, the CLI prompts interactively for a recovery key which will hang in non-interactive environments. Space names are permanent and cannot be changed after creation.
List all spaces:
storacha space ls
The active space is marked with *.
Switch active space:
storacha space use "SpaceName"
Or by DID:
storacha space use did:key:z6Mk...
View space details:
storacha space info
Shows the space DID and registered providers.
Create a UCAN delegation for another agent:
storacha delegation create AUDIENCE_DID --can store/add --can upload/add --output ./delegation.ucan
Full admin delegation:
storacha delegation create AUDIENCE_DID --can '*' --output ./admin.ucan --base64
List active delegations:
storacha delegation ls
npm install -g @storacha/clistoracha login EMAIL or switch spaces with storacha space use "Name"storacha space info to check providers. Re-register at https://console.storacha.network or create a new space.storacha space create "MyFiles" --no-recoverystoracha rm CID --shards| Action | Command |
|---|---|
| --- | --- |
| Install CLI | npm install -g @storacha/cli |
| Login | storacha login user@email.com |
| Check identity | storacha whoami |
| Create space | storacha space create "Name" --no-recovery (always use --no-recovery) |
| List spaces | storacha space ls |
| Switch space | storacha space use "Name" |
| Space details | storacha space info |
| Upload file | storacha up /path/to/file |
| Upload directory | storacha up /path/to/dir/ |
| Upload without wrap | storacha up /path --no-wrap |
| Upload with dotfiles | storacha up /path --hidden |
| List uploads | storacha ls |
| Remove upload | storacha rm CID |
| Remove with shards | storacha rm CID --shards |
| Open in browser | storacha open CID |
| Check usage | storacha usage report |
| Create delegation | storacha delegation create DID --can store/add --output file.ucan |
| List delegations | storacha delegation ls |
did:key. Each space tracks its own uploads independently.https://storacha.link/ipfs/CIDhttps://CID.ipfs.storacha.linkstoracha. It was previously called w3 during the web3.storage era.共 1 个版本