0xnyk/xint/SKILL.md
X Intelligence CLI — search, analyze, and engage on X/Twitter from the terminal. Use when: (1) user says "x research", "search x for", "search twitter for", "what are people saying about", "what's twitter saying", "check x for", "x search", "search x", "find tweets about", "monitor x for", "track followers", (2) user is working on something where recent X discourse would provide useful context (new library releases, API changes, product launches, cultural events, industry drama), (3) user wants to find what devs/experts/community thinks about a topic, (4) user needs real-time monitoring ("watch"), (5) user wants AI-powered analysis ("analyze", "sentiment", "report"), (6) user wants to sync bookmarks to Obsidian ("sync bookmarks", "capture bookmarks", "bookmark research", "save my bookmarks to obsidian"). Also supports: bookmarks, likes, following (read/write), trending topics, Grok AI analysis, and cost tracking. Export as JSON, JSONL (pipeable), CSV, or Markdown. Non-goals: Not for posting tweets, not for DMs, not for enterprise features. Requires OAuth for user-context operations (bookmarks, likes, following, diff).
npx skillsauth add openclaw/skills xintInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
General-purpose agentic research over X/Twitter. Decompose any research question into targeted searches, iteratively refine, follow threads, deep-dive linked content, and synthesize into a sourced briefing.
For X API details (endpoints, operators, response format): read references/x-api.md.
This skill requires sensitive credentials. Follow these guidelines:
.env)data/ directory: cache, exports, snapshots, OAuth tokenswatch and stream can send data to webhook endpointshttps:// (http:// is accepted only for localhost/loopback)XINT_WEBHOOK_ALLOWED_HOSTS=hooks.example.com,*.internal.examplemcp --sse) and disabled by default--webhook) and disabled by defaultcurl | bash when possiblebun run xint.ts mcp starts a local MCP server exposing xint commands as tools--sse is explicitly enabled--policy read_only|engagement|moderation and budget guardrailsAll commands run from the project directory:
# Set your environment variables
export X_BEARER_TOKEN="your-token"
bun run xint.ts search "<query>" [options]
Options:
--sort likes|impressions|retweets|recent — sort order (default: likes)--since 1h|3h|12h|1d|7d — time filter (default: last 7 days). Also accepts minutes (30m) or ISO timestamps.--min-likes N — filter by minimum likes--min-impressions N — filter by minimum impressions--pages N — pages to fetch, 1-5 (default: 1, 100 tweets/page)--limit N — max results to display (default: 15)--quick — quick mode: 1 page, max 10 results, auto noise filter, 1hr cache, cost summary--from <username> — shorthand for from:username in query--quality — filter low-engagement tweets (>=10 likes, post-hoc)--no-replies — exclude replies--sentiment — AI-powered per-tweet sentiment analysis (via Grok). Shows positive/negative/neutral/mixed with scores.--save — save results to data/exports/--json — raw JSON output--jsonl — one JSON object per line (optimized for Unix pipes: | jq, | tee)--csv — CSV output for spreadsheet analysis--markdown — markdown output for research docsAuto-adds -is:retweet unless query already includes it. All searches display estimated API cost.
Examples:
bun run xint.ts search "AI agents" --sort likes --limit 10
bun run xint.ts search "from:elonmusk" --sort recent
bun run xint.ts search "(opus 4.6 OR claude) trading" --pages 2 --save
bun run xint.ts search "$BTC (revenue OR fees)" --min-likes 5
bun run xint.ts search "AI agents" --quick
bun run xint.ts search "AI agents" --quality --quick
bun run xint.ts search "solana memecoins" --sentiment --limit 20
bun run xint.ts search "startup funding" --csv > funding.csv
bun run xint.ts search "AI" --jsonl | jq 'select(.metrics.likes > 100)'
bun run xint.ts profile <username> [--count N] [--replies] [--json]
Fetches recent tweets from a specific user (excludes replies by default).
bun run xint.ts thread <tweet_id> [--pages N]
Fetches full conversation thread by root tweet ID.
bun run xint.ts tweet <tweet_id> [--json]
bun run xint.ts article <url> [--json] [--full] [--ai <text>]
Fetches and extracts full article content from any URL using xAI's web_search tool (Grok reads the page). Returns clean text with title, author, date, and word count. Requires XAI_API_KEY.
Also supports X tweet URLs — automatically extracts the linked article from the tweet and fetches it.
Options:
--json — structured JSON output (title, content, author, published, wordCount, ttr)--full — return full article text without truncation (default truncates to ~5000 chars)--model <name> — Grok model (default: grok-4)--ai <text> — analyze article with Grok AI (passes content to analyze command)Examples:
# Fetch article from URL
bun run xint.ts article https://example.com/blog/post
# Auto-extract article from X tweet URL and analyze
bun run xint.ts article "https://x.com/user/status/123456789" --ai "Summarize key takeaways"
# Fetch + analyze with AI
bun run xint.ts article https://techcrunch.com/article --ai "What are the main points?"
# Full content without truncation
bun run xint.ts article https://blog.example.com/deep-dive --full
Agent usage: When search results include tweets with article links, use article to read the full content. Search results now include article titles and descriptions from the X API (shown as 📰 lines), so you can decide which articles are worth a full read. Prioritize articles that:
bun run xint.ts bookmarks [options] # List bookmarked tweets
bun run xint.ts bookmark <tweet_id> # Bookmark a tweet
bun run xint.ts unbookmark <tweet_id> # Remove a bookmark
Bookmark list options:
--limit N — max bookmarks to display (default: 20)--since <dur> — filter by recency (1h, 1d, 7d, etc.)--query <text> — client-side text filter--json — raw JSON output--markdown — markdown output--save — save to data/exports/--no-cache — skip cacheRequires OAuth. Run auth setup first.
bun run xint.ts likes [options] # List your liked tweets
bun run xint.ts like <tweet_id> # Like a tweet
bun run xint.ts unlike <tweet_id> # Unlike a tweet
Likes list options: Same as bookmarks (--limit, --since, --query, --json, --no-cache).
Requires OAuth with like.read and like.write scopes.
bun run xint.ts following [username] [--limit N] [--json]
Lists accounts you (or another user) follow. Defaults to the authenticated user.
Requires OAuth with follows.read scope.
bun run xint.ts trends [location] [options]
Fetches trending topics. Tries the official X API trends endpoint first; falls back to search-based hashtag frequency estimation if unavailable.
Options:
[location] — location name or WOEID number (default: worldwide)--limit N — number of trends to display (default: 20)--json — raw JSON output--no-cache — bypass the 15-minute cache--locations — list all known location namesExamples:
bun run xint.ts trends # Worldwide
bun run xint.ts trends us --limit 10 # US top 10
bun run xint.ts trends japan --json # Japan, JSON output
bun run xint.ts trends --locations # List all locations
bun run xint.ts analyze "<query>" # Ask Grok a question
bun run xint.ts analyze --tweets <file> # Analyze tweets from JSON file
bun run xint.ts search "topic" --json | bun run xint.ts analyze --pipe # Pipe search results
Uses xAI's Grok API (OpenAI-compatible). Requires XAI_API_KEY in env or .env.
Options:
--model <name> — grok-4, grok-4-1-fast (default), grok-3, grok-3-mini, grok-2--tweets <file> — path to JSON file containing tweets--pipe — read tweet JSON from stdinExamples:
bun run xint.ts analyze "What are the top AI agent frameworks right now?"
bun run xint.ts search "AI agents" --json | bun run xint.ts analyze --pipe "Which show product launches?"
bun run xint.ts analyze --model grok-3 "Deep analysis of crypto market sentiment"
For “recent sentiment / what X is saying” without using cookies/GraphQL, use xAI’s hosted x_search tool.
Script:
python3 scripts/xai_x_search_scan.py --help
Store first-party artifacts (reports, logs) in xAI Collections and semantic-search them later.
Script:
python3 scripts/xai_collections.py --help
Env:
XAI_API_KEY (api.x.ai): file upload + searchXAI_MANAGEMENT_API_KEY (management-api.x.ai): collections management + attaching documentsNotes:
--dry-run when wiring new cron jobs.bun run xint.ts reposts <tweet_id> [--limit N] [--json]
Look up users who reposted a specific tweet. Useful for engagement analysis and OSINT.
Examples:
bun run xint.ts reposts 1234567890
bun run xint.ts reposts 1234567890 --limit 50 --json
bun run xint.ts users "<query>" [--limit N] [--json]
Search for X users by keyword. Uses the /2/users/search endpoint.
Examples:
bun run xint.ts users "AI researcher"
bun run xint.ts users "solana developer" --limit 10 --json
bun run xint.ts watch "<query>" [options]
Polls a search query on an interval, shows only new tweets. Great for monitoring topics during catalysts, tracking mentions, or feeding live data into downstream tools.
Options:
--interval <dur> / -i — poll interval: 30s, 1m, 5m, 15m (default: 5m)--webhook <url> — POST new tweets as JSON to this URL (https:// required for remote hosts)--jsonl — output as JSONL instead of formatted text (for piping to tee, jq, etc.)--quiet — suppress per-poll headers (just show tweets)--limit N — max tweets to show per poll--sort likes|impressions|retweets|recent — sort orderPress Ctrl+C to stop — prints session stats (duration, total polls, new tweets found, total cost).
Examples:
bun run xint.ts watch "solana memecoins" --interval 5m
bun run xint.ts watch "@vitalikbuterin" --interval 1m
bun run xint.ts watch "AI agents" -i 30s --webhook https://hooks.example.com/ingest
bun run xint.ts watch "breaking news" --jsonl | tee -a feed.jsonl
Agent usage: Use watch when you need continuous monitoring of a topic. For one-off checks, use search instead. The watch command auto-stops if the daily budget is exceeded.
bun run xint.ts diff <@username> [options]
Tracks follower/following changes over time using local snapshots. First run creates a baseline; subsequent runs show who followed/unfollowed since last check.
Options:
--following — track who the user follows (instead of their followers)--history — view all saved snapshots for this user--json — structured JSON output--pages N — pages of followers to fetch (default: 5, 1000 per page)Requires OAuth (auth setup first). Snapshots stored in data/snapshots/.
Examples:
bun run xint.ts diff @vitalikbuterin # First run: create snapshot
bun run xint.ts diff @vitalikbuterin # Later: show changes
bun run xint.ts diff @0xNyk --following # Track who you follow
bun run xint.ts diff @solana --history # View snapshot history
Agent usage: Use diff to detect notable follower changes for monitored accounts. Combine with watch for comprehensive account monitoring. Run periodically (e.g., daily) to build a history of follower changes.
bun run xint.ts report "<topic>" [options]
Generates comprehensive markdown intelligence reports combining search results, optional sentiment analysis, and AI-powered summary via Grok.
Options:
--sentiment — include per-tweet sentiment analysis--accounts @user1,@user2 — include per-account activity sections--model <name> — Grok model for AI summary (default: grok-4-1-fast)--pages N — search pages to fetch (default: 2)--save — save report to data/exports/Examples:
bun run xint.ts report "AI agents"
bun run xint.ts report "solana" --sentiment --accounts @aaboronkov,@rajgokal --save
bun run xint.ts report "crypto market" --model grok-3 --sentiment --save
Agent usage: Use report when the user wants a comprehensive briefing on a topic. This is the highest-level command — it runs search, sentiment, and analysis in one pass and produces a structured markdown report. For quick pulse checks, use search --quick instead.
bun run xint.ts costs # Today's costs
bun run xint.ts costs week # Last 7 days
bun run xint.ts costs month # Last 30 days
bun run xint.ts costs all # All time
bun run xint.ts costs budget # Show budget info
bun run xint.ts costs budget set 2.00 # Set daily limit to $2
bun run xint.ts costs reset # Reset today's data
Tracks per-call API costs with daily aggregates and configurable budget limits.
bun run xint.ts watchlist # Show all
bun run xint.ts watchlist add <user> [note] # Add account
bun run xint.ts watchlist remove <user> # Remove account
bun run xint.ts watchlist check # Check recent from all
bun run xint.ts auth setup [--manual] # Set up OAuth 2.0 (PKCE)
bun run xint.ts auth status # Check token status
bun run xint.ts auth refresh # Manually refresh tokens
Required scopes: bookmark.read bookmark.write tweet.read users.read like.read like.write follows.read offline.access
bun run xint.ts cache clear # Clear all cached results
15-minute TTL. Avoids re-fetching identical queries.
When doing deep research (not just a quick search), follow this loop:
Turn the research question into 3-5 keyword queries using X search operators:
from: specific known experts(broken OR bug OR issue OR migration)(shipped OR love OR fast OR benchmark)url:github.com or url: specific domains-is:retweet (auto-added), add -is:reply if neededRun each query via CLI. After each, assess:
from: specifically?thread command?When a tweet has high engagement or is a thread starter:
bun run xint.ts thread <tweet_id>
Search results now include article titles and descriptions from the X API (shown as 📰 in output). Use these to decide which links are worth a full read, then fetch with xint article:
bun run xint.ts article <url> # terminal display
bun run xint.ts article <url> --json # structured output
bun run xint.ts article <url> --full # no truncation
Prioritize links that:
For complex research, pipe search results into Grok for synthesis:
bun run xint.ts search "topic" --json | bun run xint.ts analyze --pipe "Summarize themes and sentiment"
Group findings by theme, not by query:
### [Theme/Finding Title]
[1-2 sentence summary]
- @username: "[key quote]" (NL, NI) [Tweet](url)
- @username2: "[another perspective]" (NL, NI) [Tweet](url)
Resources shared:
- [Resource title](url) — [what it is]
Use --save flag to save to data/exports/.
Only activate when user explicitly asks to sync bookmarks to Obsidian (e.g., "sync bookmarks", "capture bookmarks", "bookmark research", "save my bookmarks to obsidian").
Fetches recent X bookmarks, analyzes article content, and saves as structured research notes in the Obsidian inbox. Requires OAuth + Obsidian vault path (~/obsidian/nyk/inbox/).
Step 1 — Fetch bookmarks:
xint bookmarks --limit {count} --json --policy engagement {--since flag if provided} {--query flag if provided}
Parse JSON output. Each bookmark has: id, text, username, name, created_at, metrics, urls, tweet_url.
Step 2 — Classify: For each bookmark, determine type:
x.com/i/article/...) or thread with 3+ linked tweetsStep 3 — Analyze content:
Step 4 — Deduplicate: Before creating files, check for existing notes:
grep -rl "{tweet_id}" ~/obsidian/nyk/inbox/ 2>/dev/null
Skip bookmarks that already have notes.
Step 5 — Generate research notes at ~/obsidian/nyk/inbox/research-{slug}.md:
---
id: research-{slug}
created: {today's date}
type: research
status: inbox
tags: [{auto-detected tags}]
source: x-bookmarks
tweet_id: "{tweet_id}"
description: {one-line summary}
---
Content sections: Signal (author, engagement, tweet URL) → Core Thesis → Key Findings (bullets) → Why It Resonated (engagement analysis) → Actionable Takeaways (checklist) → Related (wikilinks). Apply 2-4 tags per note.
Step 6 — Summary report: Output a table of processed bookmarks (author, topic, engagement, file), counts of new/skipped/total.
| Content Pattern | Tags |
|----------------|------|
| AI agents, deployment, orchestration | ai-agents, agent-deployment |
| Enterprise, SaaS, business | enterprise, business-strategy |
| Trading, quant, markets, DeFi | quantitative-finance, prediction-markets |
| Claude, LLM, prompting | ai-ml-research, llm-engineering |
| Security, hacking, CTF | security-governance |
| Design, UI/UX, frontend | design, frontend |
| Startup, growth, marketing | startup, marketing |
| Coding, engineering, architecture | software-engineering |
inbox/ — promotion to knowledge/graph/ happens via knowledge-doctor pipeline[[wikilinks]] for internal cross-references (never standard markdown links)All API calls are tracked in data/api-costs.json. The budget system warns when approaching limits but does not block calls (passive).
X API v2 pay-per-use rates:
Default daily budget: $1.00 (adjustable via costs budget set <N>).
-is:reply, use --sort likes, narrow keywordsOR, remove restrictive operators-$ -airdrop -giveaway -whitelistfrom: or --min-likes 50has:linksxint/
├── SKILL.md (this file — agent instructions)
├── xint.ts (CLI entry point)
├── lib/
│ ├── api.ts (X API wrapper: search, thread, profile, tweet)
│ ├── article.ts (full article content fetcher via xAI web_search)
│ ├── bookmarks.ts (bookmark read — OAuth)
│ ├── cache.ts (file-based cache, 15min TTL)
│ ├── costs.ts (API cost tracking & budget)
│ ├── engagement.ts (likes, like/unlike, following, bookmark write — OAuth)
│ ├── followers.ts (follower/following tracking + snapshot diffs)
│ ├── format.ts (terminal, markdown, CSV, JSONL formatters)
│ ├── grok.ts (xAI Grok analysis integration)
│ ├── oauth.ts (OAuth 2.0 PKCE auth + token refresh)
│ ├── reposts.ts (repost/retweet lookup)
│ ├── report.ts (intelligence report generation)
│ ├── sentiment.ts (AI-powered sentiment analysis via Grok)
│ ├── trends.ts (trending topics — API + search fallback)
│ ├── users.ts (user search by keyword)
│ └── watch.ts (real-time monitoring with polling)
├── data/
│ ├── api-costs.json (cost tracking data)
│ ├── oauth-tokens.json (OAuth tokens — chmod 600)
│ ├── watchlist.json (accounts to monitor)
│ ├── exports/ (saved research)
│ ├── snapshots/ (follower/following snapshots for diff)
│ └── cache/ (auto-managed)
└── references/
└── x-api.md (X API endpoint reference)
The Package API provides agent memory package management:
| Tool | Purpose | Auth |
|------|---------|------|
| xint_package_create | Create ingest job from topic query | XINT_PACKAGE_API_KEY |
| xint_package_status | Get package metadata + freshness | XINT_PACKAGE_API_KEY |
| xint_package_query | Query packages, return claims + citations | XINT_PACKAGE_API_KEY |
| xint_package_refresh | Trigger new snapshot | XINT_PACKAGE_API_KEY |
| xint_package_search | Search package catalog | XINT_PACKAGE_API_KEY |
| xint_package_publish | Publish to shared catalog | XINT_PACKAGE_API_KEY |
Workflow:
xint_package_create -> creates package with topic query + sourcesxint_package_status -> poll until status is "ready"xint_package_query -> retrieve claims with citationsxint_package_refresh -> trigger re-ingest when data is stalexint_package_publish -> share to catalog when quality is confirmed--quick flag for initial discovery (1 page, 1hr cache, noise filter)--fields id,text,metrics.likes to reduce response sizexint_search with limit: 5 for quick checksxint_costs to check budget before expensive operationsxint_watch for polling instead of repeated searchesxint_report for topic intelligence instead of multiple searchesxint_search with limit=15: ~3KB responsexint_profile with count=20: ~4KB responsexint_article: 1-10KB depending on article lengthxint_trends: ~2KB response--fields flag to reduce output to only needed fields| Error Code | Retryable | Agent Action | Example |
|-----------|-----------|-------------|---------|
| RATE_LIMITED | Yes | Wait retry_after_ms, then retry | 429 from X API |
| AUTH_FAILED | No | Stop, report missing credential | Missing X_BEARER_TOKEN |
| NOT_FOUND | No | Skip resource, try alternative | Deleted tweet |
| BUDGET_DENIED | No | Stop, use xint costs budget set N | Daily limit exceeded |
| POLICY_DENIED | No | Stop, escalate to user | Need --policy=engagement |
| VALIDATION_ERROR | No | Fix parameter, retry | Invalid tweet_id format |
| TIMEOUT | Yes | Retry after 5s | Network timeout |
| API_ERROR | If 5xx | Retry after 30s for 5xx, stop for 4xx | X API outage |
When a tool fails, try the next option:
xint_search (X API v2, fast, real-time)xint_xsearch (xAI Grok search via grok-4-1-fast, AI-enhanced, requires XAI_API_KEY)For article fetching:
xint_article with tweet URL (extracts inline X Article)xint_article with article URL (web fetch via grok-4)xint_search for tweets about the topicFor user discovery:
xint_users (search by keyword, new /2/users/search endpoint)xint_search with from: operator for known usernamesxint_reposts to find engaged users on specific tweetstools
Use when the user wants to connect to, test, or use the McDonalds service at mcp.mcd.cn, including checking authentication, probing MCP endpoints, listing tools, or calling McDonalds MCP tools through a reusable local CLI.
development
Web scraping platform — Twitter/X data, Vinted marketplace, and general web scraping API
development
SlowMist AI Agent Security Review — comprehensive security framework for skills, repositories, URLs, on-chain addresses, and products (Claude Code version)
data-ai
去除中文文本中的 AI 写作痕迹,使其读起来自然。基于维基百科 AI 写作特征指南,检测 24 种 AI 模式。触发词:humanizer-cn、去除 AI 痕迹、去除 AI 写作痕迹、中文文本人性化。