
Security News
AI Has Taken Over Open Source
Vibe coding at scale is reshaping how packages are created, contributed, and selected across the software supply chain
twitterapi-mcp-server
Advanced tools
MCP server for TwitterAPI.io - Access Twitter data through a unified API interface
A Model Context Protocol (MCP) server that provides access to Twitter data through the TwitterAPI.io service. This server enables Claude and other MCP clients to interact with Twitter's ecosystem without requiring Twitter developer account approval.
Attribution: This project is a fork of kinhunt/twitterapi-mcp with bug fixes and improvements to match the official TwitterAPI.io documentation.
npx twitterapi-mcp-server
npm install -g twitterapi-mcp-server
npm install twitterapi-mcp-server
new1_xxxxxxxxxxxxxxxxxxxxx| Variable | Required | Description |
|---|---|---|
TWITTERAPI_API_KEY | Yes | Your TwitterAPI.io API key |
PROXY_URL | No | Proxy URL for enterprise environments |
HTTP_PROXY | No | Alternative proxy configuration |
HTTPS_PROXY | No | Alternative proxy configuration |
Add this to your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"twitterapi": {
"command": "npx",
"args": ["-y", "twitterapi-mcp-server"],
"env": {
"TWITTERAPI_API_KEY": "your_api_key_here"
}
}
}
}
{
"mcpServers": {
"twitterapi": {
"command": "npx",
"args": ["-y", "twitterapi-mcp-server"],
"env": {
"TWITTERAPI_API_KEY": "your_api_key_here",
"PROXY_URL": "http://proxy.company.com:8080"
}
}
}
}
Add to your Cursor MCP settings (.cursor/mcp.json):
{
"mcpServers": {
"twitterapi": {
"command": "npx",
"args": ["-y", "twitterapi-mcp-server"],
"env": {
"TWITTERAPI_API_KEY": "your_api_key_here"
}
}
}
}
Add to your Claude Code MCP settings (~/.claude/settings.json):
{
"mcpServers": {
"twitterapi": {
"command": "npx",
"args": ["-y", "twitterapi-mcp-server"],
"env": {
"TWITTERAPI_API_KEY": "your_api_key_here"
}
}
}
}
If you prefer to run with Node directly instead of npx:
{
"mcpServers": {
"twitterapi": {
"command": "node",
"args": ["/path/to/twitterapi-mcp-server/build/index.js"],
"env": {
"TWITTERAPI_API_KEY": "your_api_key_here"
}
}
}
}
| Tool | Description | Required Params | Optional Params |
|---|---|---|---|
get_user_by_username | Get user details by username | username | - |
get_user_by_id | Get user details by user ID | user_id | - |
get_user_followers | Get user's followers (200/page) | username | cursor, pageSize |
get_user_following | Get users someone follows (200/page) | username | cursor, pageSize |
search_users | Search for users by keyword | query | cursor |
| Tool | Description | Required Params | Optional Params |
|---|---|---|---|
get_user_tweets | Get tweets from a user (20/page) | username or userId | cursor, includeReplies |
search_tweets | Search tweets by keywords | query | queryType (Latest/Top), cursor |
get_tweet_by_id | Get tweets by IDs | tweet_ids (array) | - |
get_tweet_replies | Get replies to a tweet (20/page) | tweetId | cursor, sinceTime, untilTime |
| Tool | Description | Required Params | Optional Params |
|---|---|---|---|
login_user | Login to Twitter account | user_name, email, password, proxy | totp_secret |
create_tweet | Post new tweets | tweet_text, proxy | reply_to_tweet_id, attachment_url, media_ids |
// Get user by username
await get_user_by_username({ username: "elonmusk" })
// Get user followers with pagination
await get_user_followers({
username: "elonmusk",
pageSize: 100
})
// Get next page using cursor
await get_user_followers({
username: "elonmusk",
cursor: "next_cursor_from_previous_response"
})
// Search latest tweets
await search_tweets({
query: "artificial intelligence",
queryType: "Latest"
})
// Search top/popular tweets
await search_tweets({
query: "OpenAI",
queryType: "Top"
})
// Advanced search with operators
await search_tweets({
query: "AI from:elonmusk since:2024-01-01"
})
// Get user's recent tweets
await get_user_tweets({ username: "openai" })
// Get user's tweets including replies
await get_user_tweets({
username: "openai",
includeReplies: true
})
// Get specific tweets by IDs
await get_tweet_by_id({
tweet_ids: ["1234567890123456789", "9876543210987654321"]
})
// Get replies to a tweet
await get_tweet_replies({
tweetId: "1234567890123456789"
})
// Login first (requires residential proxy)
await login_user({
user_name: "your_username",
email: "your_email@example.com",
password: "your_password",
proxy: "http://user:pass@proxy:port"
})
// Post a tweet
await create_tweet({
tweet_text: "Hello from MCP!",
proxy: "http://user:pass@proxy:port"
})
// Reply to a tweet
await create_tweet({
tweet_text: "Great point!",
reply_to_tweet_id: "1234567890123456789",
proxy: "http://user:pass@proxy:port"
})
All list endpoints return paginated results with cursor-based navigation:
{
"data": [...],
"has_next_page": true,
"next_cursor": "cursor_string_for_next_page"
}
To get the next page, pass the next_cursor value as the cursor parameter in your next request.
TwitterAPI.io offers pay-as-you-go pricing:
| Operation | Price |
|---|---|
| Tweets | $0.15 per 1,000 |
| User profiles | $0.18 per 1,000 |
| Followers/Following | $0.15 per 1,000 |
| Login | $0.003 per call |
| Create tweet | $0.003 per call |
git clone https://github.com/Jing-yilin/twitterapi-mcp-server.git
cd twitterapi-mcp-server
npm install
npm run build
# Using bun
bun test
# Or with npm (requires bun installed)
npm test
# Set your API key
export TWITTERAPI_API_KEY="your_api_key"
# Test tools list
echo '{"jsonrpc": "2.0", "id": 1, "method": "tools/list", "params": {}}' | node build/index.js
# Test a tool call
echo '{"jsonrpc": "2.0", "id": 1, "method": "tools/call", "params": {"name": "get_user_by_username", "arguments": {"username": "elonmusk"}}}' | node build/index.js
twitterapi-mcp-server/
├── src/
│ ├── index.ts # Main server implementation
│ ├── index.test.ts # Unit tests
│ └── integration.test.ts # Integration tests
├── build/ # Compiled JavaScript
├── package.json
├── tsconfig.json
└── README.md
The server handles common errors:
| Error | Cause | Solution |
|---|---|---|
| 401 Unauthorized | Invalid API key | Check your TWITTERAPI_API_KEY |
| 402 Payment Required | Insufficient credits | Add credits at TwitterAPI.io dashboard |
| 429 Rate Limited | Too many requests | Wait and retry, or reduce request rate |
| 400 Bad Request | Invalid parameters | Check parameter names and formats |
login_cookie from login is stored in memory only for the sessionTWITTERAPI_API_KEY environment variable is setnpm run build to compile TypeScripthttp://user:pass@host:portHTTPS_PROXY variablegit checkout -b feature/amazing-feature)git commit -m 'Add amazing feature')git push origin feature/amazing-feature)This project is licensed under the MIT License - see the LICENSE file for details.
Note: This is an unofficial MCP server for TwitterAPI.io. Make sure to comply with Twitter's Terms of Service when using this tool.
FAQs
MCP server for TwitterAPI.io - Access Twitter data through a unified API interface
We found that twitterapi-mcp-server demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Vibe coding at scale is reshaping how packages are created, contributed, and selected across the software supply chain

Security News
npm invalidated all granular access tokens that bypass 2FA after a fresh Mini Shai-Hulud wave compromised 323 npm packages. Staged publishing also entered public preview.

Research
/Security News
Compromised npm package art-template delivered a Coruna-like iOS Safari exploit framework through a watering-hole attack.