From x-research
Researches X/Twitter via xAI Grok API: account digests, thread/post analysis, trending topics, custom searches for Telegram post ideas.
npx claudepluginhub artwist-polyakov/polyakov-claude-skills --plugin x-researchThis skill uses the workspace's default tool permissions.
Research X/Twitter via xAI Grok API. Grok's `x_search` tool searches X in real-time and returns synthesized analysis with citations.
Guides Next.js Cache Components and Partial Prerendering (PPR) with cacheComponents enabled. Implements 'use cache', cacheLife(), cacheTag(), revalidateTag(), static/dynamic optimization, and cache debugging.
Guides building MCP servers enabling LLMs to interact with external services via tools. Covers best practices, TypeScript/Node (MCP SDK), Python (FastMCP).
Generates original PNG/PDF visual art via design philosophy manifestos for posters, graphics, and static designs on user request.
Research X/Twitter via xAI Grok API. Grok's x_search tool searches X in real-time and returns synthesized analysis with citations.
Get an xAI API key at console.x.ai, then:
cp config/.env.example config/.env
Edit config/.env: paste your key into XAI_API_KEY, configure accounts and topics.
Without .env: skill works with explicit --accounts, --query, --topics.
With .env: digests and trending ready out of the box.
Category registry (same pattern as telegram-channel-parser):
X_CATEGORIES=ai,crypto # available categories
X_DEFAULT_CATEGORY=ai # default for "digest" without specifying
X_ACCOUNTS_AI_LABEL="AI & ML"
X_ACCOUNTS_AI=elonmusk,sama,AndrewYNg
X_TOPICS_AI=AI,LLM,GPT,Claude,agents,AGI
Agent algorithm for digest/trending:
config/.envX_CATEGORIES to get available categoriesX_ACCOUNTS_<ID> = handles, X_TOPICS_<ID> = topics, X_ACCOUNTS_<ID>_LABEL = nameX_DEFAULT_CATEGORY--accounts / --topicsPriority: --accounts/--topics explicit > category from .env > agent asks.
Details: config/README.md.
cache/runs/. Use --prefer-cache to reuse..env, auto-fallback if unavailable.# Default category from .env
bash scripts/digest.sh --period today
# Specific category
bash scripts/digest.sh --category crypto --period week
# Explicit accounts (no .env needed)
bash scripts/digest.sh --accounts "elonmusk,sama" --period today
Returns: structured items (author, date, summary, engagement, URL, topic) + Telegram post ideas.
# By description
bash scripts/analyze.sh --query "Elon Musk's thread about open source AI"
# By URL
bash scripts/analyze.sh --url "https://x.com/elonmusk/status/123456" --query "context about the post"
# With time period
bash scripts/analyze.sh --query "debate about AI regulation" --period week
Returns: main thesis, key arguments, community reaction, sentiment, interesting findings, Telegram post angles.
# Default topics from .env
bash scripts/trending.sh --period today
# Specific topics
bash scripts/trending.sh --topics "Bitcoin,Ethereum,DeFi" --period today
# Category
bash scripts/trending.sh --category ai --period week
Returns: structured items (topic, summary, sentiment, key voices, engagement) + Telegram post ideas.
# Free search
bash scripts/search.sh --query "Claude 4 reactions" --period week
# Search within specific accounts
bash scripts/search.sh --query "AI safety" --accounts "sama,ylecun" --period today
Returns: structured items + narrative summary + Telegram post ideas.
# Read last digest without making an API call
bash scripts/digest.sh --category ai --period today --prefer-cache
# Find artifact manually
bash scripts/find_latest.sh --script digest --category ai --period today
bash scripts/<script>.sh [params]
| Script | Description | Key params |
|---|---|---|
digest.sh | Digest of subscribed accounts | --category, --accounts, --period |
analyze.sh | Deep analysis of post/thread/topic | --query, --url, --period |
trending.sh | Trending topics by interests | --category, --topics, --period |
search.sh | Custom search query | --query, --accounts, --period |
find_latest.sh | Find latest cached artifact | --script, --category, --query, --period |
| Param | Required | Default | Description |
|---|---|---|---|
--accounts | no | from .env | X handles, comma-separated (without @) |
--category | no | from .env | Category ID from X_CATEGORIES |
--period | no | today | Time range: 1h, today, yesterday, week, Nd |
--query | varies | — | Search query or post description |
--topics | no | from .env | Topics for trending, comma-separated |
--url | no | — | X post URL for analyze |
--limit | no | 30 | Max output lines |
--prefer-cache | no | — | Use latest cached artifact if available |
--refresh | no | — | Force live request (default behavior) |
Each run saves a JSON artifact in cache/runs/ with full metadata:
{
"meta": {
"script": "digest",
"category": "ai",
"handles": ["elonmusk", "sama"],
"period": "today",
"from_date": "2026-04-01",
"to_date": "2026-04-01",
"model": "grok-4-1-fast-reasoning",
"created_at": "2026-04-01T14:30:22Z",
"run_id": "a1b2c3"
},
"items": [...],
"ideas": [...],
"summary": "...",
"text": "...",
"citations": [...]
}
Index: cache/index.jsonl — one JSON line per run for fast lookup.
allowed_x_handles (auto-batched if more)grok-4.20-reasoningAdvanced scenarios: references/API_REFERENCE.md