--- name: bird description: X/Twitter CLI for reading, searching, posting, and engagement via cookies. homepage: https://bird.fast metadata: {"clawdbot":{"emoji":"🐦","requires":{"bins":["bird"]},"install":[{"id":"brew","kind":"brew","formula":"steipete/tap/bird","bins":["bird"],"label":"Install bird (brew)"},{"id":"npm","kind":"npm","package":"@steipete/bird","bins":["bird"],"label":"Install bird (npm)"}]}} --- # bird 🐦 Fast X/Twitter CLI using GraphQL + cookie auth. No API keys needed. ## Install ```bash # npm/pnpm/bun (Node ≥ 20) npm install -g @steipete/bird # Homebrew (macOS, prebuilt binary) brew install steipete/tap/bird # One-shot (no install) bunx @steipete/bird whoami ``` ## Authentication `bird` uses your existing browser session (cookie auth). No password prompt. Resolution order: 1. CLI flags: `--auth-token`, `--ct0` 2. Environment: `AUTH_TOKEN`, `CT0` 3. Browser cookies via `--cookie-source` (default: Safari → Chrome → Firefox) For Chromium variants (Arc/Brave), use `--chrome-profile-dir `. ## Commands ### Account & Auth ```bash bird whoami # Show logged-in account bird check # Show credential sources bird query-ids --fresh # Refresh GraphQL query ID cache ``` ### Reading Tweets ```bash bird read # Read a single tweet bird # Shorthand for read bird thread # Full conversation thread bird replies # List replies to a tweet ``` ### Timelines ```bash bird home # Home timeline (For You) bird home --following # Following timeline bird user-tweets @handle -n 20 # User's profile timeline bird mentions # Tweets mentioning you bird mentions --user @handle # Mentions of another user ``` ### Search ```bash bird search "query" -n 10 bird search "from:steipete" --all --max-pages 3 ``` ### News & Trending ```bash bird news -n 10 # AI-curated from Explore tabs bird news --ai-only # Filter to AI-curated only bird news --sports # Sports tab bird news --with-tweets # Include related tweets bird trending # Alias for news ``` ### Lists ```bash bird lists # Your lists bird lists --member-of # Lists you're a member of bird list-timeline -n 20 # Tweets from a list ``` ### Bookmarks & Likes ```bash bird bookmarks -n 10 bird bookmarks --folder-id # Specific folder bird bookmarks --include-parent # Include parent tweet bird bookmarks --author-chain # Author's self-reply chain bird bookmarks --full-chain-only # Full reply chain bird unbookmark bird likes -n 10 ``` ### Social Graph ```bash bird following -n 20 # Users you follow bird followers -n 20 # Users following you bird following --user # Another user's following bird about @handle # Account origin/location info ``` ### Engagement Actions ```bash bird follow @handle # Follow a user bird unfollow @handle # Unfollow a user ``` The library also exposes like/unlike/retweet/unretweet/bookmark mutations. ### Posting ```bash bird tweet "hello world" bird reply "nice thread!" bird tweet "check this out" --media image.png --alt "description" ``` **⚠️ Posting risks**: Twitter may flag automated posting (error 226). `bird` falls back to legacy endpoints, but for high-volume or sensitive posting, consider using the browser tool instead. ## Media Uploads ```bash bird tweet "hi" --media img.png --alt "description" bird tweet "pics" --media a.jpg --media b.jpg # Up to 4 images bird tweet "video" --media clip.mp4 # Or 1 video ``` Supported: jpg, jpeg, png, webp, gif, mp4, mov. ## Pagination Commands supporting pagination: `replies`, `thread`, `search`, `bookmarks`, `likes`, `list-timeline`, `following`, `followers`, `user-tweets` ```bash bird bookmarks --all # Fetch all pages bird bookmarks --max-pages 3 # Limit pages bird bookmarks --cursor # Resume from cursor bird replies --all --delay 1000 # Delay between pages (ms) ``` ## Output Options ```bash --json # JSON output --json-full # JSON with raw API response --plain # No emoji, no color (script-friendly) --no-emoji # Disable emoji --no-color # Disable ANSI colors (or set NO_COLOR=1) --quote-depth n # Max quoted tweet depth in JSON (default: 1) ``` ## Global Options ```bash --auth-token # Set auth_token cookie --ct0 # Set ct0 cookie --cookie-source # safari|chrome|firefox (repeatable) --chrome-profile # Chrome profile name --chrome-profile-dir # Chromium profile dir (Arc/Brave) --firefox-profile # Firefox profile --timeout # Request timeout --cookie-timeout # Cookie extraction timeout ``` ## Config File `~/.config/bird/config.json5` (global) or `./.birdrc.json5` (project): ```json5 { cookieSource: ["safari", "chrome"], chromeProfileDir: "/path/to/Arc/Profile", timeoutMs: 20000, quoteDepth: 1 } ``` Environment variables: `BIRD_TIMEOUT_MS`, `BIRD_COOKIE_TIMEOUT_MS`, `BIRD_QUOTE_DEPTH` ## Library Usage ```typescript import { TwitterClient, resolveCredentials } from '@steipete/bird'; const { cookies } = await resolveCredentials({ cookieSource: 'safari' }); const client = new TwitterClient({ cookies }); const searchResult = await client.search('from:steipete', 50); const newsResult = await client.getNews(10, { aiOnly: true }); ``` ## Troubleshooting ### Query IDs stale (404 errors) ```bash bird query-ids --fresh ``` ### Cookie extraction fails - Check browser is logged into X - Try different `--cookie-source` - For Arc/Brave: use `--chrome-profile-dir` ### Rate limited (429) - Space out requests - Reading is generous; posting/engagement is watched more closely ### Error 226 on posting Twitter flagged as automated. `bird` auto-retries with legacy endpoint, but may still fail. Use browser for reliable posting. --- **TL;DR**: Read/search/engage with CLI. Post carefully or use browser. 🐦