x-twitter-mcp-server
The X (Twitter) MCP Server is a Model Context Protocol server designed to facilitate natural language interaction with Twitter using AI tools. It supports comprehensive Twitter API functionalities, including user and tweet management, search, and rate limit handling. The server is optimized for integration with environments like Claude Desktop, offering a streamlined approach to manage Twitter through AI interfaces.
X (Twitter) MCP server
A Model Context Protocol (MCP) server for interacting with Twitter (X) via AI tools. This server allows you to fetch tweets, post tweets, search Twitter, manage followers, and more, all through natural language commands in AI Tools.
Features
- Fetch user profiles, followers, and following lists.
- Post, delete, and favorite tweets.
- Search Twitter for tweets and trends.
- Manage bookmarks and timelines.
- Built-in rate limit handling for the Twitter API.
- Uses Twitter API v2 with proper authentication (API keys and tokens), avoiding the username/password hack to minimize the risk of account suspensions.
- Provides a complete implementation of Twitter API v2 endpoints for user management, tweet management, timelines, and search functionality.
Prerequisites
- Python 3.10 or higher: Ensure Python is installed on your system.
- Twitter Developer Account: You need API credentials (API Key, API Secret, Access Token, Access Token Secret, and Bearer Token) from the Twitter Developer Portal.
- Optional: Claude Desktop: Download and install the Claude Desktop app from the Anthropic website.
- Optional: Node.js (for MCP integration): Required for running MCP servers in Claude Desktop.
- A package manager like
uv
orpip
for Python dependencies.
Installation
Option 1: Installing via Smithery (Recommended)
To install X (Twitter) MCP server for Claude Desktop automatically via Smithery:
npx -y @smithery/cli install @rafaljanicki/x-twitter-mcp-server --client claude
Option 2: Install from PyPI
The easiest way to install x-twitter-mcp
is via PyPI:
pip install x-twitter-mcp
Option 3: Install from Source
If you prefer to install from the source repository:
-
Clone the Repository:
git clone https://github.com/rafaljanicki/x-twitter-mcp-server.git cd x-twitter-mcp-server
-
Set Up a Virtual Environment (optional but recommended):
python -m venv .venv source .venv/bin/activate # On Windows: .venv\Scripts\activate
-
Install Dependencies: Using
uv
(recommended, as the project usesuv.lock
):uv sync
Alternatively, using
pip
:pip install .
-
Configure Environment Variables:
- Create a
.env
file in the project root (you can copy.env.example
if provided). - Add your Twitter API credentials:
TWITTER_API_KEY=your_api_key TWITTER_API_SECRET=your_api_secret TWITTER_ACCESS_TOKEN=your_access_token TWITTER_ACCESS_TOKEN_SECRET=your_access_token_secret TWITTER_BEARER_TOKEN=your_bearer_token
- Create a
Running the Server
You can run the server in two ways:
Option 1: Using the CLI Script
The project defines a CLI script x-twitter-mcp-server
.
If installed from PyPI:
x-twitter-mcp-server
If installed from source with uv
:
uv run x-twitter-mcp-server
Option 2: Using FastMCP Directly (Source Only)
If you installed from source and prefer to run the server using FastMCP’s development mode:
fastmcp dev src/x_twitter_mcp/server.py
The server will start and listen for MCP connections. You should see output like:
Starting TwitterMCPServer...
Using with Claude Desktop
To use this MCP server with Claude Desktop, you need to configure Claude to connect to the server. Follow these steps:
Step 1: Install Node.js
Claude Desktop uses Node.js to run MCP servers. If you don’t have Node.js installed:
- Download and install Node.js from nodejs.org.
- Verify installation:
node --version
Step 2: Locate Claude Desktop Configuration
Claude Desktop uses a claude_desktop_config.json
file to configure MCP servers.
- Windows:
%APPDATA%\Claude\claude_desktop_config.json
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json
If the file doesn’t exist, create it.
Step 3: Configure the MCP Server
Edit claude_desktop_config.json
to include the x-twitter-mcp
server. Replace /path/to/x-twitter-mcp-server
with the actual path to your project directory (if installed from source) or the path to your Python executable (if installed from PyPI).
If installed from PyPI:
{
"mcpServers": {
"x-twitter-mcp": {
"command": "x-twitter-mcp-server",
"args": [],
"env": {
"PYTHONUNBUFFERED": "1",
"TWITTER_API_KEY": "your_api_key",
"TWITTER_API_SECRET": "your_api_secret",
"TWITTER_ACCESS_TOKEN": "your_access_token",
"TWITTER_ACCESS_TOKEN_SECRET": "your_access_token_secret",
"TWITTER_BEARER_TOKEN": "your_bearer_token"
}
}
}
}
If installed from source with uv
:
{
"mcpServers": {
"x-twitter-mcp": {
"command": "uv",
"args": [
"--directory",
"/path/to/x-twitter-mcp-server",
"run",
"x-twitter-mcp-server"
],
"env": {
"PYTHONUNBUFFERED": "1"
}
}
}
}
"command": "x-twitter-mcp-server"
: Uses the CLI script directly if installed from PyPI."env"
: If installed from PyPI, you may need to provide environment variables directly in the config (since there’s no.env
file). If installed from source, the.env
file will be used."env": {"PYTHONUNBUFFERED": "1"}
: Ensures output is unbuffered for better logging in Claude.
Step 4: Restart Claude Desktop
- Quit Claude Desktop completely.
- Reopen Claude Desktop to load the new configuration.
Step 5: Verify Connection
- Open Claude Desktop.
- Look for a hammer or connector icon in the input area (bottom right corner). This indicates MCP tools are available.
- Click the icon to see the available tools from
x-twitter-mcp
, such aspost_tweet
,search_twitter
,get_user_profile
, etc.
Step 6: Test with Claude
You can now interact with Twitter using natural language in Claude Desktop. Here are some example prompts:
-
Fetch a User Profile:
Get the Twitter profile for user ID 123456.
Claude will call the
get_user_profile
tool and return the user’s details. -
Post a Tweet:
Post a tweet saying "Hello from Claude Desktop! #MCP"
Claude will use the
post_tweet
tool to post the tweet and confirm the action. -
Search Twitter:
Search Twitter for recent tweets about AI.
Claude will invoke the
search_twitter
tool and return relevant tweets. -
Get Trends:
What are the current trending topics on Twitter?
Claude will use the
get_trends
tool to fetch trending topics.
When prompted, grant Claude permission to use the MCP tools for the chat session.
Available Tools
Below is a list of all tools provided by the x-twitter-mcp
server, along with example executions in Claude Desktop using natural language prompts.
User Management Tools
get_user_profile
- Description: Get detailed profile information for a user.
- Claude Desktop Example:
Claude will return the user’s profile details, including ID, name, username, profile image URL, and description.Get the Twitter profile for user ID 123456789.
get_user_by_screen_name
- Description: Fetches a user by screen name.
- Claude Desktop Example:
Claude will return the user’s profile details.Get the Twitter user with screen name "example_user".
get_user_by_id
- Description: Fetches a user by ID.
- Claude Desktop Example:
Claude will return the user’s profile details.Fetch the Twitter user with ID 987654321.
get_user_followers
- Description: Retrieves a list of followers for a given user.
- Claude Desktop Example:
Claude will return a list of up to 50 followers.Get the followers of user ID 123456789, limit to 50.
get_user_following
- Description: Retrieves users the given user is following.
- Claude Desktop Example:
Claude will return a list of up to 50 users.Who is user ID 123456789 following? Limit to 50 users.
get_user_followers_you_know
- Description: Retrieves a list of common followers.
- Claude Desktop Example:
Claude will return a list of up to 50 common followers (simulated by filtering followers).Get common followers for user ID 123456789, limit to 50.
get_user_subscriptions
- Description: Retrieves a list of users to which the specified user is subscribed.
- Claude Desktop Example:
Claude will return a list of up to 50 users (using following as a proxy for subscriptions).Get the subscriptions for user ID 123456789, limit to 50.
Tweet Management Tools
post_tweet
- Description: Post a tweet with optional media, reply, and tags.
- Claude Desktop Example:
Claude will post the tweet and return the tweet details.Post a tweet saying "Hello from Claude Desktop! #MCP"
delete_tweet
- Description: Delete a tweet by its ID.
- Claude Desktop Example:
Claude will delete the tweet and confirm the action.Delete the tweet with ID 123456789012345678.
get_tweet_details
- Description: Get detailed information about a specific tweet.
- Claude Desktop Example:
Claude will return the tweet’s details, including ID, text, creation date, and author ID.Get details for tweet ID 123456789012345678.
create_poll_tweet
- Description: Create a tweet with a poll.
- Claude Desktop Example:
Claude will create the poll tweet and return the tweet details.Create a poll tweet with the question "What's your favorite color?" and options "Red", "Blue", "Green" for 60 minutes.
vote_on_poll
- Description: Vote on a poll.
- Claude Desktop Example:
Claude will return a mock response (since Twitter API v2 doesn’t support poll voting).Vote "Blue" on the poll in tweet ID 123456789012345678.
favorite_tweet
- Description: Favorites a tweet.
- Claude Desktop Example:
Claude will favorite the tweet and confirm the action.Like the tweet with ID 123456789012345678.
unfavorite_tweet
- Description: Unfavorites a tweet.
- Claude Desktop Example:
Claude will unfavorite the tweet and confirm the action.Unlike the tweet with ID 123456789012345678.
bookmark_tweet
- Description: Adds the tweet to bookmarks.
- Claude Desktop Example:
Claude will bookmark the tweet and confirm the action.Bookmark the tweet with ID 123456789012345678.
delete_bookmark
- Description: Removes the tweet from bookmarks.
- Claude Desktop Example:
Claude will remove the bookmark and confirm the action.Remove the bookmark for tweet ID 123456789012345678.
delete_all_bookmarks
- Description: Deletes all bookmarks.
- Claude Desktop Example:
Claude will delete all bookmarks and confirm the action.Delete all my Twitter bookmarks.
Timeline & Search Tools
get_timeline
- Description: Get tweets from your home timeline (For You).
- Claude Desktop Example:
Claude will return up to 20 tweets from your For You timeline.Show my Twitter For You timeline, limit to 20 tweets.
get_latest_timeline
- Description: Get tweets from your home timeline (Following).
- Claude Desktop Example:
Claude will return up to 20 tweets from your Following timeline.Show my Twitter Following timeline, limit to 20 tweets.
search_twitter
- Description: Search Twitter with a query.
- Claude Desktop Example:
Claude will return up to 10 recent tweets about AI.Search Twitter for recent tweets about AI, limit to 10.
get_trends
- Description: Retrieves trending topics on Twitter.
- Claude Desktop Example:
Claude will return up to 10 trending topics.What are the current trending topics on Twitter? Limit to 10.
get_highlights_tweets
- Description: Retrieves highlighted tweets from a user’s timeline.
- Claude Desktop Example:
Claude will return up to 20 tweets from the user’s timeline (simulated as highlights).Get highlighted tweets from user ID 123456789, limit to 20.
get_user_mentions
- Description: Get tweets mentioning a specific user.
- Claude Desktop Example:
Claude will return up to 20 tweets mentioning the user.Get tweets mentioning user ID 123456789, limit to 20.
Troubleshooting
-
Server Not Starting:
- Ensure your
.env
file has all required Twitter API credentials (if installed from source). - If installed from PyPI, ensure environment variables are set in
claude_desktop_config.json
or your shell. - Check the terminal output for errors when running
x-twitter-mcp-server
. - Verify that
uv
or your Python executable is correctly installed and accessible.
- Ensure your
-
Claude Not Detecting the Server:
- Confirm the path in
claude_desktop_config.json
is correct. - Ensure the
command
andargs
point to the correct executable and script. - Restart Claude Desktop after updating the config file.
- Check Claude’s Developer Mode logs (Help → Enable Developer Mode → Open MCP Log File) for errors.
- Confirm the path in
-
Rate Limit Errors:
- The server includes rate limit handling, but if you hit Twitter API limits, you may need to wait for the reset window (e.g., 15 minutes for tweet actions).
-
Syntax Warnings:
- If you see
SyntaxWarning
messages from Tweepy, they are due to docstring issues in Tweepy with Python 3.13. The server includes a warning suppression to handle this.
- If you see
Contributing
Contributions are welcome! Please open an issue or submit a pull request on the GitHub repository.
License
This project is licensed under the MIT License. See the LICENSE
file for details.
Author
- Rafal Janicki -