Skillshub pinme
This skill should be used when the user asks to "deploy", "upload", "publish", or "pin" any files, folders, frontend projects, or static websites to IPFS. Also activates when user mentions "pinme", "IPFS", or wants to share files via decentralized storage.
install
source · Clone the upstream repo
git clone https://github.com/ComeOnOliver/skillshub
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ComeOnOliver/skillshub "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/glitternetwork/pinme/pinme" ~/.claude/skills/comeonoliver-skillshub-pinme && rm -rf "$T"
manifest:
skills/glitternetwork/pinme/pinme/SKILL.mdsource content
PinMe Skill
Use PinMe CLI to upload files and get a preview URL.
When to Use
General File Upload
- User wants to upload any files or folders to IPFS
- User wants to share files via decentralized storage
- User mentions "pinme", "pin", "IPFS", or "upload to IPFS"
Website Deployment
- User requests deployment of a frontend project
- User wants to deploy a static website
- After building a frontend project (Vue, React, Next.js, etc.)
Upload Steps
1. Check if PinMe is Installed
pinme --version
If not installed:
npm install -g pinme
2. Identify Upload Target
For general files:
- Use the file or directory path specified by the user
- Can be any file type: images, documents, archives, etc.
For website deployment: Look for build output directories (in priority order):
- Vue/React/Vite default outputdist/
- Create React App outputbuild/
- Next.js static exportout/
- Pure static projectspublic/
3. Execute Upload
pinme upload <path>
Examples:
# Upload a single file pinme upload ./document.pdf # Upload a folder pinme upload ./my-folder # Upload website build output pinme upload dist
4. Return Result
After successful upload, return the preview URL:
https://pinme.eth.limo/#/preview/<hash>
Users can visit the preview page to:
- View or download the uploaded files
- Get a fixed domain:
https://<name>.pinit.eth.limo
Router Mode Check
Before building a frontend project for IPFS deployment, ensure it uses hash mode routing (e.g.,
/#/about). History mode (e.g., /about) will cause 404 errors on sub-routes when deployed to IPFS, because there is no server to handle fallback routing.
- React: Use
instead ofHashRouterBrowserRouter - Vue: Use
instead ofcreateWebHashHistory()createWebHistory()
Important Rules
DO:
- Verify the file or directory exists before uploading
- Return the preview URL to the user
DO NOT:
- Upload
node_modules/ - Upload
files.env - Upload
directory.git/ - Upload empty or non-existent paths
For website deployment, also avoid:
- Uploading source code instead of build output
- Uploading configuration files (package.json, tsconfig.json, etc.)
Common Workflows
General File Upload
# Upload a single file pinme upload ./image.png # Upload a folder pinme upload ./my-documents # Upload with specific path pinme upload /path/to/files
Website Deployment
Vue/Vite
npm run build pinme upload dist
React CRA
npm run build pinme upload build
Next.js Static
npm run build npm run export # or next export pinme upload out
Error Handling
| Error | Solution |
|---|---|
| Run |
| Check path exists |
| Check file/folder permissions |
| Upload failed | Check network, retry |
Other Commands
# List upload history pinme list pinme ls -l 5 # Remove uploaded file pinme rm <hash>