Grist MCP Server

Grist MCP Server

Connects Claude Desktop to Grist spreadsheets, enabling users to browse documents, tables, and columns through natural language. It supports reading, writing, and querying data using standard record operations or direct SQL queries.

Category
Visit Server

README

Grist MCP Server

MCP (Model Context Protocol) server that connects Claude Desktop to Grist spreadsheets. It dynamically discovers documents, tables, and columns, and lets you read, write, and query data using natural language.

Features

  • list_documents -- browse all orgs, workspaces, and docs
  • list_tables -- discover tables inside a document
  • list_columns -- inspect column names, types, and labels
  • get_records -- read rows with filters, sorting, and limits
  • add_records -- insert new rows
  • update_records -- modify existing rows
  • delete_records -- remove rows by ID
  • query_sql -- run SQL SELECT queries directly

Quick Start

1. Clone and install

git clone <repo-url>
cd grist-mcp-server
python -m venv .venv && source .venv/bin/activate
pip install -r requirements.txt

2. Configure environment

Copy the example file and fill in your credentials:

cp .env.example .env
Variable Required Description
GRIST_API_KEY Yes API key from your Grist profile
GRIST_BASE_URL Yes Base URL of your Grist instance
GRIST_DOC_ID No Default document ID (saves typing)

3. Run locally (stdio transport)

python server.py

4. Run with HTTP transport (for Render)

MCP_TRANSPORT=streamable-http python server.py

Connect to Claude Desktop

Add the following to your claude_desktop_config.json:

Local (stdio)

{
  "mcpServers": {
    "grist": {
      "command": "python",
      "args": ["/absolute/path/to/server.py"],
      "env": {
        "GRIST_API_KEY": "your_api_key",
        "GRIST_BASE_URL": "https://altitudedm.getgrist.com",
        "GRIST_DOC_ID": "9PRy5Jf5ayS3dDL9iYRHmU"
      }
    }
  }
}

Remote (Render deployment)

{
  "mcpServers": {
    "grist": {
      "url": "https://your-app.onrender.com/mcp"
    }
  }
}

Set environment variables on Render instead of in the config file.

Deploy on Render

  1. Push this repo to GitHub.
  2. Create a new Web Service on Render.
  3. Connect the GitHub repo.
  4. Render will auto-detect the render.yaml configuration.
  5. Add GRIST_API_KEY in the Render dashboard environment variables.
  6. Deploy.

The server will be available at https://your-app.onrender.com/mcp.

Usage Examples

Explore data

You: What documents do I have in Grist?
Claude: (calls list_documents) You have 3 documents: ...

You: Show me the tables in "Client Tracker"
Claude: (calls list_tables) The document has 4 tables: Clients, Projects, Invoices, Notes

You: What columns does the Clients table have?
Claude: (calls list_columns) Columns: name (Text), email (Text), status (Choice), ...

Read and filter

You: Show me the first 10 active clients
Claude: (calls get_records with filter={"status":["active"]}, limit=10)

You: How many invoices were created this month?
Claude: (calls query_sql with SQL: SELECT COUNT(*) FROM Invoices WHERE date >= '2025-01-01')

Write data

You: Add a new client: name=ACME Corp, status=active
Claude: (calls add_records) Created record with ID 42.

You: Mark client 42 as inactive
Claude: (calls update_records with id=42, fields={"status":"inactive"})

You: Delete client 99
Claude: (calls delete_records with record_ids=[99])

Running Tests

pip install pytest pytest-asyncio
pytest tests/ -v

Project Structure

grist-mcp-server/
├── server.py          # MCP server entry point (8 tools)
├── grist_client.py    # Async Grist API client
├── requirements.txt   # Python dependencies
├── render.yaml        # Render deployment config
├── .env.example       # Environment variable template
├── .gitignore
├── tests/
│   └── test_grist_client.py
└── README.md

License

MIT

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
Kagi MCP Server

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.

Official
Featured
Python
graphlit-mcp-server

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.

Official
Featured
TypeScript
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
E2B

E2B

Using MCP to run code via e2b.

Official
Featured