grok-search-mcp
MCP server that enables coding agents to search X/Twitter and the web through the local Grok CLI, providing better search results than default Codex or Claude search without requiring an API key.
README
grok-search-mcp
MCP server that brings Grok CLI web and X/Twitter search to Codex and Claude Code.
This project exists to give Codex and Claude Code a better search lane when
their built-in search experience is not enough. Grok's search, especially for
X/Twitter content, is often noticeably better than what these coding agents can
reach on their own. grok-search-mcp exposes that advantage through a small,
isolated MCP server, so agents can ask Grok for web or X search results without
turning Grok into a general chat dependency.
This project is intentionally narrow:
- no xAI API key
- no API credits
- no image or video tools
- no generic Grok chat tool
- only web search and X/Twitter search through
grok
The server runs grok with an isolated HOME, so it does not load your normal
Cursor/Claude/Grok user-level MCP servers, hooks, or skills.
Tools
| Tool | Purpose |
|---|---|
grok_x_search |
Search X/Twitter through Grok CLI runtime search tools |
grok_web_search |
Search the web through Grok CLI runtime web search |
Both tools return a JSON string with this shape:
{
"summary": "short summary",
"items": [],
"urls": [],
"rawText": "raw Grok answer",
"diagnostics": {
"mode": "x",
"parseOk": true,
"model": "grok-build",
"isolatedHome": "/Users/me/.grok-search-mcp",
"warnings": []
}
}
If Grok does not return parseable JSON, the server keeps the raw answer and sets
diagnostics.parseOk=false.
Requirements
- Node.js 20+
- The official Grok CLI installed
- A Grok CLI account/subscription that can use search
Install Grok CLI if needed:
curl -fsSL https://x.ai/cli/install.sh | bash
One-time login
The MCP server uses a dedicated profile home, defaulting to
~/.grok-search-mcp. Log in once for that isolated profile:
GROK_BIN="/Users/zhangyuze/.grok/bin/grok" \
GROK_SEARCH_MCP_HOME="$HOME/.grok-search-mcp" \
npx -y github:z2z23n0/grok-search-mcp login
You do not need to log in for every search. Run this again only if the isolated profile token expires or is revoked.
Check the setup:
GROK_BIN="/Users/zhangyuze/.grok/bin/grok" \
GROK_SEARCH_MCP_HOME="$HOME/.grok-search-mcp" \
npx -y github:z2z23n0/grok-search-mcp doctor
doctor should report:
{
"ok": true,
"authenticated": true,
"isolation": {
"hooks": 0,
"skills": 0,
"mcpServers": 0
}
}
Client setup
Codex
Add this to ~/.codex/config.toml:
[mcp_servers.grok_search]
command = "npx"
args = ["-y", "github:z2z23n0/grok-search-mcp"]
enabled_tools = ["grok_x_search", "grok_web_search"]
default_tools_approval_mode = "auto"
startup_timeout_sec = 120
tool_timeout_sec = 240
[mcp_servers.grok_search.env]
GROK_BIN = "/Users/zhangyuze/.grok/bin/grok"
GROK_SEARCH_MCP_HOME = "/Users/zhangyuze/.grok-search-mcp"
GROK_SEARCH_MCP_MODEL = "grok-build"
NPM_CONFIG_REGISTRY = "https://registry.npmjs.org"
Restart Codex after editing MCP config.
Claude Code
Add the MCP server with Claude Code's CLI:
claude mcp add --scope user --transport stdio grok-search \
--env GROK_BIN=/Users/zhangyuze/.grok/bin/grok \
--env GROK_SEARCH_MCP_HOME=$HOME/.grok-search-mcp \
--env GROK_SEARCH_MCP_MODEL=grok-build \
--env NPM_CONFIG_REGISTRY=https://registry.npmjs.org \
-- npx -y github:z2z23n0/grok-search-mcp
Check the registration:
claude mcp list
Example prompts:
Use grok_search.grok_x_search to search X for recent @grok posts about Grok CLI.
Use grok_search.grok_web_search to search docs.x.ai for Grok Build headless scripting.
Environment
| Variable | Default | Purpose |
|---|---|---|
GROK_BIN |
grok |
Path to the Grok CLI binary |
GROK_SEARCH_MCP_HOME |
~/.grok-search-mcp |
Isolated profile home |
GROK_SEARCH_MCP_MODEL |
grok-build |
Grok CLI model |
GROK_SEARCH_MCP_TIMEOUT_MS |
180000 |
Per-call timeout |
GROK_SEARCH_MCP_MAX_TURNS |
6 |
Max Grok turns per search |
The server sets these for the Grok subprocess:
HOME=$GROK_SEARCH_MCP_HOMEXDG_CONFIG_HOME=$GROK_SEARCH_MCP_HOME/.configXDG_CACHE_HOME=$GROK_SEARCH_MCP_HOME/.cacheXDG_DATA_HOME=$GROK_SEARCH_MCP_HOME/.local/share
It also runs Grok from a temporary empty working directory instead of your repo.
Local development
npm install
npm test
npm run typecheck
npm run build
Integration tests are skipped by default because they require a logged-in isolated Grok profile:
RUN_GROK_INTEGRATION=1 npm run test:integration
Notes
grok_x_search relies on Grok CLI agent runtime behavior. It does not call the
public xAI API x_search tool, so it avoids API billing but cannot promise API
level filtering or schemas.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.