Zip1
A free URL shortener
- Shorten
- API
- MCP
- Stats
- Report URL
🤖 AI Integration (MCP)
Use zip1.io directly from AI assistants like Claude through the Model Context Protocol (MCP). Shorten URLs, retrieve analytics, and manage links using natural language commands.
🤖
AI-Powered URL Management
Talk to your URL shortener like you talk to an AI
- ✨ Natural language interface - no API syntax needed
- ⚡ Instant URL shortening from your AI assistant
- 📊 Get analytics on-demand with simple prompts
- 🔒 Create password-protected links conversationally
⚡ Quick Setup
For Claude Code (Recommended)
Claude Code supports HTTP MCP servers directly via CLI. Simply run:
Terminal
claude mcp add --transport http zip1 http://zip1.io/mcp
Verify installation:
Terminal
claude mcp list
✅ That's it! You can now use zip1.io directly from Claude Code.
For Claude Desktop
⚠️ Requires Proxy: Claude Desktop only supports stdio-based MCP servers, not HTTP servers. You'll need a local proxy to bridge the connection.
Option 1: Using mcp-client-cli (Recommended)
Install the MCP client CLI tool to bridge stdio to HTTP:
Terminal
npm install -g @modelcontextprotocol/client-cli
Then edit your Claude Desktop config file:
- macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
- Windows: %APPDATA%\Claude\claude_desktop_config.json
Add this configuration:
claude_desktop_config.json
{
  "mcpServers": {
    "zip1": {
      "command": "mcp-client",
      "args": ["http://zip1.io/mcp"]
    }
  }
}
Restart Claude Desktop and the zip1.io tools will be available.
Option 2: Custom Node.js Proxy
For advanced users, create a custom stdio-to-HTTP bridge script:
zip1-mcp-proxy.js
#!/usr/bin/env node
const https = require('https');
const readline = require('readline');
const MCP_URL = 'http://zip1.io/mcp';
const rl = readline.createInterface({
  input: process.stdin,
  output: process.stdout,
  terminal: false
});
rl.on('line', (line) => {
  const request = JSON.parse(line);
  const options = {
    method: 'POST',
    headers: {
      'Content-Type': 'application/json',
    }
  };
  const req = https.request(MCP_URL, options, (res) => {
    let data = '';
    res.on('data', (chunk) => data += chunk);
    res.on('end', () => {
      console.log(data);
    });
  });
  req.on('error', (error) => {
    console.error(JSON.stringify({
      jsonrpc: '2.0',
      id: request.id,
      error: { code: -32000, message: error.message }
    }));
  });
  req.write(JSON.stringify(request));
  req.end();
});
Make it executable and add to your Claude Desktop config:
Terminal
chmod +x zip1-mcp-proxy.js
{
  "mcpServers": {
    "zip1": {
      "command": "node",
      "args": ["/path/to/zip1-mcp-proxy.js"]
    }
  }
}
⚙️ Server Configuration
The zip1.io MCP server is available as an HTTP endpoint that any MCP-compatible client can connect to.
Server Details
| Configuration Item | Value | 
|---|---|
| Server URL | http://zip1.io/mcp | 
| Transport | HTTP (Streamable) | 
| Protocol Version | MCP 2024-11-05 | 
| Message Format | JSON-RPC 2.0 | 
| Authentication | None (rate-limited) | 
| Rate Limit | 30 requests/minute per IP | 
| Available Tools | 4 (create_short_url, get_url_stats, validate_url, generate_short_code) | 
Using with Other MCP Clients
Any MCP-compatible client that supports HTTP transport can connect to zip1.io. Here are some examples:
Direct HTTP Requests (curl)
List Available Tools
curl -X POST http://zip1.io/mcp \
  -H "Content-Type: application/json" \
  -d '{
    "jsonrpc": "2.0",
    "id": 1,
    "method": "tools/list",
    "params": {}
  }'
Create a Short URL
curl -X POST http://zip1.io/mcp \
  -H "Content-Type: application/json" \
  -d '{
    "jsonrpc": "2.0",
    "id": 2,
    "method": "tools/call",
    "params": {
      "name": "create_short_url",
      "arguments": {
        "url": "https://example.com",
        "alias": "my-link"
      }
    }
  }'
Python Client Example
Python Script
import requests
MCP_URL = "http://zip1.io/mcp"
def call_mcp_tool(tool_name, arguments):
    payload = {
        "jsonrpc": "2.0",
        "id": 1,
        "method": "tools/call",
        "params": {
            "name": tool_name,
            "arguments": arguments
        }
    }
    response = requests.post(MCP_URL, json=payload)
    return response.json()
# Example usage
result = call_mcp_tool("create_short_url", {
    "url": "https://github.com/anthropics/claude-mcp",
    "alias": "mcp-docs"
})
print(result)
Self-Hosted Configuration
If you're running your own instance of zip1.io, configure clients to point to your instance:
Claude Code
claude mcp add --transport http zip1 https://your-domain.com/mcp
Claude Desktop (with mcp-client)
{
  "mcpServers": {
    "zip1-local": {
      "command": "mcp-client",
      "args": ["http://localhost:8000/mcp"]
    }
  }
}
💬 Example Conversations
Here are some natural language prompts you can use with Claude:
Creating Short URLs
Prompt
"Shorten https://github.com/anthropics/claude-mcp for me"
Claude's Response:
✅ Short URL created: https://zip1.io/Kj9dX2
🔤 Generated code: Kj9dX2
🔗 Original URL: https://github.com/anthropics/claude-mcp
📊 View stats: https://zip1.io/stats/Kj9dX2
Custom Aliases & Passwords
Prompt
"Create a short URL for https://docs.myapp.com with alias 'docs' and password 'team2024'"
Claude's Response:
✅ Short URL created: https://zip1.io/docs
📝 Custom alias: docs
🔒 Password protected: Yes
🔗 Original URL: https://docs.myapp.com
Getting Analytics
Prompt
"Show me the stats for short code 'docs'"
Claude's Response:
📊 Statistics for: https://zip1.io/docs
👆 Total clicks: 127
👤 Unique clicks: 89
🔒 Password protected: Yes
📅 Created: 2024-01-15T10:30:00
🌍 Top countries:
1. United States: 54 clicks
2. United Kingdom: 23 clicks
3. Canada: 18 clicks
URL Validation
Prompt
"Can I shorten ftp://myserver.com/file.zip?"
Claude's Response:
❌ URL is invalid: Must include http:// or https:// protocol and a valid domain
🛠️ Available Tools
The zip1.io MCP server provides four tools that Claude can use:
| Tool | Description | Example Usage | 
|---|---|---|
| create_short_url | Create shortened URLs with optional custom aliases, passwords, and max clicks | "Shorten this URL with alias 'mylink'" | 
| get_url_stats | Retrieve detailed analytics including clicks, countries, and timestamps | "Get stats for short code 'abc123'" | 
| validate_url | Check if a URL is valid and can be shortened | "Can I shorten example.com?" | 
| generate_short_code | Generate a random short code suggestion | "Generate a random short code" | 
🔧 Technical Details
MCP Endpoint
GET /mcp
Returns server information, available tools, and configuration details.
Protocol Information
- Protocol Version: MCP 2024-11-05
- Transport: Streamable HTTP
- Message Format: JSON-RPC 2.0
- Rate Limit: 30 requests per minute per IP
Security
- All communication uses HTTPS encryption
- Passwords are hashed with bcrypt before storage
- Rate limiting prevents abuse
- Same security infrastructure as the REST API
💡 Use Cases
📝 Content Creation
Generate short URLs while writing blog posts, documentation, or social media content without leaving your AI assistant.
📊 Quick Analytics
Ask for link performance during conversations. "How many clicks did my campaign link get?"
🔐 Secure Sharing
Create password-protected links on-the-fly when sharing sensitive information in team chats.
🎯 Campaign Management
Create custom-aliased URLs for marketing campaigns with natural language commands.
🔍 Troubleshooting
Rate limiting errors?
- The MCP endpoint has a limit of 30 requests per minute
- Wait a minute and try again
Tools not appearing in Claude Code?
- Ensure the MCP server URL is accessible
- Try visiting http://zip1.io/mcp in your browser
- Verify your MCP configuration with claude mcp list
📚 Resources & Documentation
- Official MCP Documentation - Learn more about the Model Context Protocol
- MCP Python SDK - Build your own MCP servers
- REST API Documentation - Traditional API access
Ready to Get Started?
Add zip1.io to Claude Code now and start shortening URLs with AI
Quick Setup
Related Servers
- MCP Tools- Provides file system and command execution tools for LLM clients like Claude Desktop. 
- MCP Arduino Server- An MCP server for the Arduino CLI, offering tools to manage sketches, boards, libraries, and files. 
- Jetty.io- Work on dataset metadata with MLCommons Croissant validation and creation. 
- MCP-Mem0- Integrate long-term memory into AI agents using Mem0. 
- MCP All Servers- A collection of reference implementations for the Model Context Protocol (MCP), showcasing servers built with TypeScript and Python SDKs. 
- Taeks MCP Server- An example MCP server designed for deployment on Cloudflare Workers, operating without authentication. 
- Sherlog MCP Server- A persistent IPython workspace for data analysis, log processing, and multi-agent collaboration. 
- Croft Laravel- A local MCP server for Laravel developers to boost productivity with artisan commands. 
- Apache SkyWalking MCP- An MCP server for integrating AI agents with the SkyWalking observability platform and its ecosystem. 
- Qase- Interact with the Qase API for test management. Requires a QASE_API_TOKEN for authentication.