Exposes curl functionality to make HTTP requests and download files, supporting GET, POST, PUT, DELETE methods with customizable headers, timeouts, and redirects
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., "@Curl MCP Serverfetch the latest news from the BBC homepage"
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.
MCP Server for Curl
A Model Context Protocol (MCP) server that provides curl functionality, allowing AI assistants to make HTTP requests directly from their environment.
Features
HTTP Methods: Support for GET, POST, PUT, DELETE requests
File Downloads: Download files with curl
Advanced Options: Custom headers, timeouts, redirects, and more
JSON Support: Built-in JSON data handling for POST/PUT requests
User Agent: Custom User-Agent string support
Security: Safe subprocess execution with input validation
Related MCP server: browser-use MCP Server
Installation
Method 1: NPM Installation (Recommended)
# Install globally
npm install -g @247arjun/mcp-curl
# Or install locally in your project
npm install @247arjun/mcp-curlMethod 2: From Source
# Clone the repository
git clone https://github.com/247arjun/mcp-curl.git
cd mcp-curl
# Install dependencies
npm install
# Build the project
npm run build
# Optional: Link globally
npm linkMethod 3: Direct from GitHub
# Install directly from GitHub
npm install -g git+https://github.com/247arjun/mcp-curl.gitConfiguration
Claude Desktop Setup
Add to your Claude Desktop configuration file:
Location:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%/Claude/claude_desktop_config.json
Configuration:
{
"mcpServers": {
"mcp-curl": {
"command": "mcp-curl",
"args": []
}
}
}Alternative: Using npx (no global install needed)
{
"mcpServers": {
"mcp-curl": {
"command": "npx",
"args": ["@247arjun/mcp-curl"]
}
}
}Local Development Setup
{
"mcpServers": {
"mcp-curl": {
"command": "node",
"args": ["/absolute/path/to/mcp-curl/build/index.js"]
}
}
}After adding the configuration, restart Claude Desktop to load the MCP server.
Available Tools
1. curl_get
Make HTTP GET requests.
Parameters:
url(string): The URL to make the GET request toheaders(array, optional): HTTP headers in the format 'Header: Value'timeout(number, optional): Request timeout in secondsfollow_redirects(boolean, optional): Whether to follow redirectsuser_agent(string, optional): Custom User-Agent string
Example:
{
"url": "https://api.example.com/data",
"headers": ["Authorization: Bearer token"],
"timeout": 30,
"follow_redirects": true,
"user_agent": "MyApp/1.0"
}2. curl_post
Make HTTP POST requests with data.
Parameters:
url(string): The URL to make the POST request tojson_data(object, optional): JSON object to send as POST datadata(string, optional): Data to send in the POST request bodyheaders(array, optional): HTTP headerscontent_type(string, optional): Content-Type headertimeout(number, optional): Request timeout in secondsfollow_redirects(boolean, optional): Whether to follow redirects
Example:
{
"url": "https://api.example.com/data",
"json_data": {"key": "value"},
"headers": ["Content-Type: application/json"]
}3. curl_put
Make HTTP PUT requests.
Parameters:
url(string): The URL to make the PUT request tojson_data(object, optional): JSON object to send as PUT datadata(string, optional): Data to send in the PUT request bodyheaders(array, optional): HTTP headerscontent_type(string, optional): Content-Type headertimeout(number, optional): Request timeout in secondsfollow_redirects(boolean, optional): Whether to follow redirects
Example:
{
"url": "https://api.example.com/data/123",
"data": "raw data",
"content_type": "text/plain"
}4. curl_delete
Make HTTP DELETE requests.
Parameters:
url(string): The URL to make the DELETE request toheaders(array, optional): HTTP headerstimeout(number, optional): Request timeout in secondsfollow_redirects(boolean, optional): Whether to follow redirects
Example:
{
"url": "https://api.example.com/data/123",
"headers": ["Authorization: Bearer token"]
}5. curl_download
Download files.
Parameters:
url(string): The URL of the file to downloadoutput_filename(string, optional): Output filenameresume(boolean, optional): Resume partial download if file existstimeout(number, optional): Request timeout in secondsfollow_redirects(boolean, optional): Whether to follow redirects
Example:
{
"url": "https://example.com/file.zip",
"output_filename": "downloaded_file.zip",
"resume": true
}6. curl_advanced
Execute curl with custom arguments (advanced users).
Parameters:
args(array): Array of curl arguments (excluding 'curl' itself)
Example:
{
"args": ["-X", "PATCH", "-H", "Content-Type: application/json", "-d", "{\"status\":\"updated\"}", "https://api.example.com/items/1"]
}Usage Examples
Make a GET request
{
"tool": "curl_get",
"url": "https://api.example.com/users",
"headers": ["Authorization: Bearer your-token"]
}POST JSON data
{
"tool": "curl_post",
"url": "https://api.example.com/users",
"json_data": {
"name": "John Doe",
"email": "john@example.com"
}
}Download a file
{
"tool": "curl_download",
"url": "https://example.com/file.zip",
"output_filename": "download.zip"
}Development
Prerequisites
Node.js 18.0.0 or higher
npm package manager
curl command-line tool
Building
npm run buildTesting
Test the server manually:
echo '{"jsonrpc": "2.0", "id": 1, "method": "tools/list", "params": {}}' | node build/index.jsRun tests:
npm testLinting
npm run lint
npm run lint:fixProject Structure
mcp-curl/
├── src/
│ └── index.ts # Main server implementation
├── build/
│ └── index.js # Compiled JavaScript
├── test/
│ └── basic.test.js # Basic functionality tests
├── examples/
│ └── test-server.js # Example usage
├── .github/
│ └── workflows/
│ └── ci.yml # CI/CD pipeline
├── package.json # Project configuration
├── tsconfig.json # TypeScript configuration
├── .eslintrc.json # ESLint configuration
├── LICENSE # MIT License
├── DEPLOYMENT.md # Deployment guide
├── CONTRIBUTING.md # Contribution guidelines
├── CHANGELOG.md # Version history
└── README.md # This fileVerification
Test that the server is working:
# Test the built server
node build/index.js
# Should show: "Curl MCP Server running on stdio"
# Press Ctrl+C to exitTroubleshooting
Common Issues
"Command not found" error
Ensure mcp-curl is installed globally:
npm install -g @247arjun/mcp-curlOr use npx:
"command": "npx", "args": ["@247arjun/mcp-curl"]
"Permission denied" error
Check file permissions:
chmod +x build/index.jsRebuild the project:
npm run build
MCP server not appearing in Claude
Verify JSON syntax in configuration file
Restart Claude Desktop completely
Check that the command path is correct
"curl command not found"
Install curl on your system (usually pre-installed on macOS/Linux)
Windows users: Install via package manager or download from curl website
Debugging
Enable verbose logging by setting environment variable:
# For development
DEBUG=1 node build/index.js
# Test with sample input
echo '{"jsonrpc": "2.0", "method": "initialize", "params": {}}' | node build/index.jsSecurity Notes
Input validation and sanitization for all curl arguments
Restricted file operations in advanced mode
Safe subprocess execution using spawn instead of shell
No arbitrary shell command execution
Input validation with Zod schemas
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.