uploadthing-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@uploadthing-mcpUpload the image at example.com/logo.png"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
uploadthing-mcp
MCP server for UploadThing, deployable as a Cloudflare Worker.
Connect any MCP-compatible AI assistant (Littlebird, Claude, Cursor, etc.) to your UploadThing account. Upload files from remote URLs, list your files, and delete them — all via natural language.
Why this exists
Most AI tools generate images and files at temporary URLs that expire. This MCP server lets your AI assistant permanently host those assets on UploadThing's CDN — so you can embed them in READMEs, docs, or anywhere else without worrying about broken links.
It runs as a Cloudflare Worker (serverless, always-on, free tier covers most personal use), and connects to any MCP client via a plain HTTPS URL — no local process required.
Related MCP server: Remote MCP Server for Cloudflare
⚠️ UploadThing API version notice
UploadThing ships breaking changes to their SDK fairly frequently. This project currently tracks uploadthing@^7.x.
If you hit errors after a fresh install or upgrade:
Check the UploadThing changelog
Check the open issues in this repo
Pin a specific working version in
package.jsonif needed
PRs to update compatibility are very welcome.
Tools
Tool | Description |
| Download a file from any public URL and re-upload to UploadThing. Returns a permanent CDN URL at |
| List files in your UploadThing app with keys, URLs, names, and sizes. Supports |
| Delete one or more files by their file keys. |
Deploy
One-click (Cloudflare)
Click the Deploy to Cloudflare Workers button above. After deployment:
Go to Cloudflare Dashboard → Workers & Pages → your new
uploadthing-mcpworkerNavigate to Settings → Variables & Secrets
Add a secret:
UPLOADTHING_TOKEN= your UploadThing API tokenOptionally add:
AUTH_TOKEN= a bearer token of your choosing to protect the endpoint
Manual
Prerequisites: Node.js 22+, Wrangler CLI, an UploadThing account
git clone https://github.com/ppatel26/uploadthing-mcp
cd uploadthing-mcp
npm install
# Set your UploadThing token (Dashboard -> API Keys)
npx wrangler secret put UPLOADTHING_TOKEN
# Optional: protect your endpoint
npx wrangler secret put AUTH_TOKEN
npm run deployYour server will be live at:
https://uploadthing-mcp.<your-cf-subdomain>.workers.devConnect to your MCP client
Littlebird
Go to Settings → Integrations → Add MCP Server and paste your Worker URL.
Claude Desktop / Cursor
These clients use stdio transport and run MCP servers as local processes. For local use, see the original Toolbase-AI/uploadthing-mcp which inspired this project.
Other HTTP-based MCP clients
Point the client at your Worker URL. If AUTH_TOKEN is set, configure the client to send Authorization: Bearer <your-token> with each request.
Environment variables
Variable | Required | Description |
| ✅ Yes | Your UploadThing API token ( |
| Optional | A bearer token to protect the endpoint. If set, all requests must include |
Local development
# Create a .dev.vars file (gitignored) with your secrets
echo 'UPLOADTHING_TOKEN=sk_live_...' > .dev.vars
npm run dev
# Worker runs at http://localhost:8787Credits
Inspired by Toolbase-AI/uploadthing-mcp, which implements the same idea as a local stdio server.
License
MIT
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/ppatel26/uploadthing-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server