Rockhopper MCP Server
Enables AI tools like Claude, Cursor, and Copilot to interact with your Rockhopper workspace, including enrolled files, version history, reviews, comments, and cell-level change tracking.
README
Rockhopper MCP Server
MCP (Model Context Protocol) server for Rockhopper. Lets AI tools like Claude, Cursor, and Copilot interact with your Rockhopper workspace — enrolled files, version history, reviews, comments, and cell-level change tracking.
Prerequisites
- Node.js 18+
- A Rockhopper account with at least one enrolled file
- (Optional) A Personal Access Token — only required for headless / CI / scripted setups
Authentication
The server supports two auth modes. OAuth (recommended) is the default — no token to copy and paste. PAT stays available for headless scenarios.
OAuth (recommended)
On first launch, the server prints a short verification code to stderr and a URL to visit. Sign in once in your browser — the resulting bearer token is stored in your OS keychain (Keychain on macOS, Credential Manager on Windows, libsecret on Linux). Subsequent launches pick the token up silently.
Nothing to configure — just launch the server with no ROCKHOPPER_TOKEN set:
npx @rockhopper-co/mcp-server
You'll see (on stderr):
Rockhopper — sign in to authorize this MCP client.
Open: https://app.rockhopper.co/device?user_code=ABCD2345
(or visit https://app.rockhopper.co/device and enter code: ABCD2345)
Tokens default to a 60-minute lifetime. When yours expires, the next launch silently re-runs the device flow.
Linux: requires
libsecretto be installed (apt-get install libsecret-1-devon Debian/Ubuntu,dnf install libsecreton Fedora). If unavailable, fall back to the PAT path below.
Personal Access Token (headless / CI)
For non-interactive setups, generate a PAT in the Rockhopper web app under Settings > Personal Access Tokens (read-only or read-write scope) and set it as ROCKHOPPER_TOKEN. PATs take precedence over OAuth — if ROCKHOPPER_TOKEN is set, the device-grant flow is skipped.
Setup
1. Install
npm install -g @rockhopper-co/mcp-server
Or run directly with npx:
npx @rockhopper-co/mcp-server
2. Configure your AI tool
Claude Desktop / Claude Code
Add to your MCP config (~/.claude/mcp.json or Claude Desktop settings):
{
"mcpServers": {
"rockhopper": {
"command": "npx",
"args": ["-y", "@rockhopper-co/mcp-server"],
"env": {
"ROCKHOPPER_API_URL": "https://api.rockhopper.co"
}
}
}
}
Leave ROCKHOPPER_TOKEN out to use OAuth (recommended). Set it if you want PAT auth instead.
Cursor
Add to .cursor/mcp.json in your project:
{
"mcpServers": {
"rockhopper": {
"command": "npx",
"args": ["-y", "@rockhopper-co/mcp-server"],
"env": {
"ROCKHOPPER_API_URL": "https://api.rockhopper.co"
}
}
}
}
Environment Variables
| Variable | Required | Default | Description |
|---|---|---|---|
ROCKHOPPER_TOKEN |
No | — | Personal Access Token (starts with rh_pat_). When unset, OAuth device-grant flow runs on first launch. |
ROCKHOPPER_API_URL |
No | https://api.rockhopper.co |
Rockhopper API base URL |
Postman
A starter Postman collection + environment files are available in
postman/ for gateway smoke testing (/healthz, /mcp initialize,
/mcp tools/list) across local/dev/staging/production.
Regenerate artifacts with:
npm run generate:postman
Available Tools
| Tool | Description |
|---|---|
list_files |
List enrolled Excel files with optional search filter |
get_file_versions |
Get version history for a specific file |
get_file_comments |
Get comments and threaded discussions on a file |
get_reviews |
Get review requests for a version or file |
get_cell_history |
Get change history for a specific cell across versions |
search_files |
Search enrolled files by name |
get_unattributed_changes |
Get pending cell changes not yet committed to a version |
Available Resources
| Resource | URI | Description |
|---|---|---|
| Enrolled Files | rockhopper://files |
All enrolled files in workspace |
| File Detail | rockhopper://files/{fileMsId} |
Details for a specific file |
| File Versions | rockhopper://files/{fileMsId}/versions |
Version history for a file |
| Version Detail | rockhopper://versions/{versionId} |
Single version details |
| File Comments | rockhopper://files/{fileMsId}/comments |
Comments on a file |
| Version Reviews | rockhopper://versions/{versionId}/reviews |
Reviews for a version |
| Review Detail | rockhopper://reviews/{reviewId} |
Single review details |
| Team Detail | rockhopper://teams/{teamId} |
Team details with members |
| Unattributed Changes | rockhopper://files/{fileMsId}/changes |
Pending changes |
Available Prompts
| Prompt | Description |
|---|---|
summarize-file-changes |
Summarize recent version changes and unattributed edits for a file |
pending-reviews |
Show all pending review requests for the latest version of a file |
unresolved-comments |
List all unresolved comments on a file for follow-up |
file-overview |
Comprehensive overview: versions, comments, reviews, and changes |
Write Tools (requires read-write scope)
| Tool | Description |
|---|---|
create_version |
Commit uncommitted changes as a new semver version (major/minor/patch) |
discard_changes |
Discard all uncommitted changes, revert to latest committed version |
add_comment |
Add a comment to an enrolled file (optionally at a cell) |
reply_to_comment |
Reply to an existing comment thread |
resolve_comment |
Mark a comment as resolved (author only) |
create_review_request |
Request a review on a file version |
approve_review |
Approve a review request (assigned reviewer only) |
cancel_review |
Cancel a pending review request (requester only) |
update_file_description |
Update the display name of an enrolled file |
Development
# Install dependencies
npm install
# Run in dev mode (auto-restart on changes)
npm run dev
# Build
npm run build
# Run tests
npm test
# Type check
npm run typecheck
Security
- Tokens are scoped to the creating user — the MCP server can only access data the user has permission to see
read-onlytokens cannot perform write operations (comments, reviews)- All API calls go through Rockhopper's existing authorization guards
- Tokens can be revoked instantly from the Settings page
- The MCP server runs locally and communicates with the API over HTTPS
Architecture
AI Tool (Claude/Cursor) <--stdio--> mcp-server <--HTTPS--> Rockhopper API <--> PostgreSQL
The MCP server is a thin adapter. It translates MCP tool/resource requests into Rockhopper REST API calls, authenticated with the user's PAT. All authorization is enforced server-side — the MCP server has no direct database access.
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
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.