A command-line tool for interacting with the X (formerly Twitter) API, supporting both OAuth 1.0a and OAuth 2.0 authentication.
- OAuth 2.0 PKCE flow authentication
- OAuth 1.0a authentication
- Multiple OAuth 2.0 account support
- Persistent token storage
- HTTP request customization (headers, methods, body)
curl -fsSL https://raw.githubusercontent.com/xdevplatform/xurl/main/install.sh | sudo bashYou must have a developer account and app to use this tool.
xurl auth app --bearer-token BEARER_TOKENNote: For OAuth 2.0 authentication, you must specify the redirect URI in the X API developer portal.
- Create an app at the X API developer portal.
- Go to authentication settings and set the redirect URI to http://localhost:8080/callback.   
- Set the client ID and secret in your environment variables.
export CLIENT_ID=your_client_id
export CLIENT_SECRET=your_client_secret- Get your access keys:
xurl auth oauth2xurl auth oauth1 --consumer-key KEY --consumer-secret SECRET --access-token TOKEN --token-secret SECRETView authentication status:
xurl auth statusClear authentication:
xurl auth clear --all                       # Clear all tokens
xurl auth clear --oauth1                    # Clear OAuth 1.0a tokens
xurl auth clear --oauth2-username USERNAME  # Clear specific OAuth 2.0 token
xurl auth clear --bearer                    # Clear bearer tokenBasic GET request:
xurl /2/users/meCustom HTTP method:
xurl -X POST /2/tweets -d '{"text":"Hello world!"}'Add headers:
xurl -H "Content-Type: application/json" /2/tweetsSpecify authentication type:
xurl --auth oauth2 /2/users/me
xurl --auth oauth1 /2/tweets
xurl --auth app /2/users/meUse specific OAuth 2.0 account:
xurl --username johndoe /2/users/meStreaming endpoints (like /2/tweets/search/stream) are automatically detected and handled appropriately. The tool will automatically stream the response for these endpoints:
- /2/tweets/search/stream
- /2/tweets/sample/stream
- /2/tweets/sample10/stream
- /2/tweets/firehose/strea/lang/en
- /2/tweets/firehose/stream/lang/ja
- /2/tweets/firehose/stream/lang/ko
- /2/tweets/firehose/stream/lang/pt
For example:
xurl /2/tweets/search/streamYou can also force streaming mode for any endpoint using the --stream or -s flag:
xurl -s /2/users/mexurl can help you quickly set up a temporary webhook URL to receive events from the X API. This is useful for development and testing.
- 
Start the local webhook server with ngrok: Run the webhook startcommand. This will start a local server and use ngrok to create a public URL that forwards to your local server. You will be prompted for your ngrok authtoken if it's not already configured via theNGROK_AUTHTOKENenvironment variable.xurl webhook start # Or with a specific port and output file for POST bodies xurl webhook start -p 8081 -o webhook_events.logThe command will output an ngrok URL (e.g., https://your-unique-id.ngrok-free.app/webhook). Note this URL.
- 
Register the webhook with the X API: Use the ngrok URL obtained in the previous step to register your webhook. You'll typically use app authentication for this. # Replace https://your-ngrok-url.ngrok-free.app/webhook with the actual URL from the previous step xurl --auth app /2/webhooks -d '{"url": "<your ngrok url>"}' -X POST Your local xurl webhook startserver will then handle the CRC handshake from Twitter and log incoming POST events (and write them to a file if-owas used).
The tool supports uploading media files to the X API using the chunked upload process.
Upload a media file:
xurl media upload path/to/file.mp4With custom media type and category:
xurl media upload --media-type image/jpeg --category tweet_image path/to/image.jpgCheck media upload status:
xurl media status MEDIA_IDWait for media processing to complete:
xurl media status --wait MEDIA_IDYou can also use the main command with the -F flag for direct media uploads:
- First, initialize the upload:
xurl -X POST '/2/media/upload?command=INIT&total_bytes=FILE_SIZE&media_type=video/mp4&media_catefory=tweet_video'- Then, append the media chunks:
xurl -X POST -F path/to/file.mp4 '/2/media/upload?command=APPEND&media_id=MEDIA_ID&segment_index=0'- Finally, finalize the upload:
xurl -X POST '/2/media/upload?command=FINALIZE&media_id=MEDIA_ID'- Check the status:
xurl '/2/media/upload?command=STATUS&media_id=MEDIA_ID'Tokens are stored securely in ~/.xurl in your home directory.
Contributions are welcome!
This project is open-sourced under the MIT License - see the LICENSE file for details.