Skip to main content
Glama
proofsh

GranolaAI MCP Server

by proofsh

GranolaAI MCP Server

Python 3.12+ License: MIT MCP

๐ŸŽ™๏ธ AI-Powered Meeting Intelligence for Claude Desktop

An experimental Model Context Protocol (MCP) server that bridges Granola.ai meeting intelligence with Claude Desktop. Access your meeting transcripts, notes, and insights directly through natural language conversations.

โœจ Features

  • ๐Ÿ” Meeting Search โ€” Search meetings by title, content, participants, and transcript content

  • ๐Ÿ“‹ Meeting Details โ€” Get comprehensive meeting metadata with local timezone display

  • ๐Ÿ“ Full Transcript Access โ€” Retrieve complete meeting conversations with speaker identification

  • ๐Ÿ“„ Rich Document Content โ€” Access actual meeting notes, summaries, and structured content

  • ๐Ÿ“Š Pattern Analysis โ€” Analyze patterns across meetings (participants, frequency, topics)

  • ๐ŸŒ Timezone Intelligence โ€” All timestamps automatically display in your local timezone

  • ๐Ÿ”’ 100% Local Processing โ€” No external API calls; all data stays on your machine

๐Ÿ—๏ธ Architecture

flowchart TB
    subgraph Client["๐Ÿ‘ค Client Layer"]
        CD[Claude Desktop]
    end
    
    subgraph MCP["๐Ÿ”Œ MCP Protocol Layer"]
        MCP_STDIO[MCP stdio Transport]
    end
    
    subgraph Server["โš™๏ธ Granola MCP Server"]
        GMCS[GranolaMCPServer]
        
        subgraph Handlers["Request Handlers"]
            LIST[list_tools]
            CALL[call_tool]
        end
        
        subgraph Tools["Available Tools"]
            SEARCH[search_meetings]
            DETAILS[get_meeting_details]
            TRANSCRIPT[get_meeting_transcript]
            DOCS[get_meeting_documents]
            ANALYZE[analyze_meeting_patterns]
        end
        
        subgraph Cache["Cache Management"]
            LOAD[_load_cache]
            PARSE[_parse_cache_data]
            EXTRACT[_extract_document_panel_content]
        end
    end
    
    subgraph Data["๐Ÿ’พ Data Layer"]
        CACHE_FILE[(Granola Cache<br/>cache-v*.json)]
        MODELS[Pydantic Models<br/>MeetingMetadata<br/>MeetingDocument<br/>MeetingTranscript]
    end
    
    CD -->|stdio| MCP_STDIO
    MCP_STDIO -->|MCP Protocol| GMCS
    GMCS --> LIST
    GMCS --> CALL
    CALL --> SEARCH
    CALL --> DETAILS
    CALL --> TRANSCRIPT
    CALL --> DOCS
    CALL --> ANALYZE
    GMCS --> LOAD
    LOAD --> PARSE
    PARSE --> EXTRACT
    PARSE -->|reads| CACHE_FILE
    PARSE --> MODELS

Data Flow

sequenceDiagram
    participant User as ๐Ÿ‘ค User
    participant Claude as ๐Ÿค– Claude Desktop
    participant Server as โš™๏ธ MCP Server
    participant Cache as ๐Ÿ’พ Granola Cache

    User->>Claude: "Search for meetings about quarterly planning"
    Claude->>Server: MCP: search_meetings(query)
    Server->>Cache: Read cache file
    Cache-->>Server: Raw JSON data
    Server->>Server: Parse & validate with Pydantic
    Server->>Server: Search across titles, participants, transcripts
    Server-->>Claude: Matching meetings with metadata
    Claude-->>User: Formatted meeting results

    User->>Claude: "Get transcript from yesterday's meeting"
    Claude->>Server: MCP: get_meeting_transcript(id)
    Server->>Server: Lookup transcript in cache
    Server-->>Claude: Full transcript with speakers
    Claude-->>User: Readable conversation format

๐Ÿ› ๏ธ Tech Stack

Component

Technology

Language

Python 3.12+

MCP SDK

mcp>=1.0.0

Data Validation

Pydantic 2.x

Package Manager

uv (recommended) or pip

Build System

Hatchling

Release Automation

python-semantic-release

๐Ÿ“ฆ Installation

Prerequisites

  • uv package manager

  • macOS with Granola.ai installed

Claude Desktop

Add to your claude_desktop_config.json:

macOS: ~/Library/Application Support/Claude/claude_desktop_config.json

{
  "mcpServers": {
    "granola": {
      "command": "uvx",
      "args": ["granola-mcp-server"]
    }
  }
}

Then restart Claude Desktop.

Claude Code

claude mcp add granola -- uvx granola-mcp-server

Cursor

Add Granola MCP to Cursor

Updating

uvx caches the package after first run. To update to the latest version:

uvx --refresh granola-mcp-server

Then restart your MCP client.

Manual installation (alternative)

If you prefer to install from source:

cd ~
git clone https://github.com/proofgeist/granola-mcp-server
cd granola-mcp-server
uv sync

Then configure your MCP client to run the server directly:

{
  "mcpServers": {
    "granola": {
      "command": "uv",
      "args": ["--directory", "/Users/YOUR_USERNAME/granola-mcp-server", "run", "granola-mcp-server"]
    }
  }
}

To update a source install: git pull && uv sync

pip (alternative)

pip install granola-mcp-server

Then configure your MCP client to run granola-mcp-server.

Environment Variables

Variable

Description

Default

GRANOLA_PARSE_PANELS

Enable parsing of document panels for rich notes

1 (enabled)

TZ

Override local timezone detection

Auto-detected

Set GRANOLA_PARSE_PANELS=0 to disable document panel parsing if you encounter issues.

๐Ÿš€ Usage

Once configured, restart Claude Desktop and start interacting with your Granola meetings using natural language:

Search & Discovery

  • "Search for meetings about quarterly planning"

  • "Show me yesterday's meetings"

  • "Find meetings with David from this week"

  • "List all my recent standup meetings"

Transcript Access

  • "Get the transcript from yesterday's IA meeting"

  • "What was discussed in the Float rollback planning meeting?"

  • "Show me the full conversation from the David Tanner meeting"

Content Analysis

  • "Analyze participant patterns from last month"

  • "What documents are associated with the product review meeting?"

  • "Search for mentions of 'schema labeling' in meeting transcripts"

Available Tools

Tool

Description

Parameters

search_meetings

Search meetings by title, content, participants

query (string), limit (int, optional)

get_meeting_details

Get detailed information about a meeting

meeting_id (string)

get_meeting_transcript

Get full transcript with speaker identification

meeting_id (string)

get_meeting_documents

Get documents and notes associated with a meeting

meeting_id (string)

analyze_meeting_patterns

Analyze patterns across meetings

pattern_type (enum: topics/participants/frequency), date_range (optional)

๐Ÿงช Development

Running Tests

# Run panel parsing test
uv run python test_server.py

# Test with real cache file
uv run python test_real_cache.py

Running the Server Directly

uv run granola-mcp-server

Or using the run script:

uv run python run_server.py

Project Structure

granola-mcp-server/
โ”œโ”€โ”€ granola_mcp_server/
โ”‚   โ”œโ”€โ”€ __init__.py          # Package initialization
โ”‚   โ”œโ”€โ”€ server.py            # Main MCP server implementation (~750 lines)
โ”‚   โ””โ”€โ”€ models.py            # Pydantic data models
โ”œโ”€โ”€ .github/
โ”‚   โ””โ”€โ”€ workflows/
โ”‚       โ””โ”€โ”€ release.yml      # Semantic release automation
โ”œโ”€โ”€ tests/
โ”‚   โ”œโ”€โ”€ test_server.py       # Unit tests with synthetic cache
โ”‚   โ””โ”€โ”€ test_real_cache.py   # Integration tests with real data
โ”œโ”€โ”€ pyproject.toml           # Python package configuration + semantic-release config
โ”œโ”€โ”€ run_server.py            # Entry point wrapper
โ”œโ”€โ”€ INSTALL.md               # Detailed installation guide
โ”œโ”€โ”€ LICENSE                  # MIT License
โ””โ”€โ”€ README.md                # This file

๐Ÿ”’ Security & Privacy

Feature

Status

100% Local Processing

โœ… All data stays on your machine

No External API Calls

โœ… No data sent to external services

Granola Permissions Respected

โœ… Uses existing Granola.ai access controls

Read-Only Access

โœ… Server only reads from Granola's cache

๐Ÿ“Š Performance

  • Fast Loading: Sub-2 second cache loading for hundreds of meetings

  • Rich Content: Extracts 25,000+ character transcripts and meeting notes

  • Efficient Search: Multi-field search across titles, content, participants, and transcripts

  • Memory Optimized: Lazy loading with intelligent content parsing

  • Production Ready: Successfully processes real Granola data (11.7MB cache files)

  • Scalable: Handles large datasets with 500+ transcript segments per meeting

๐Ÿ› Troubleshooting

Common Issues

"Cache file not found"

# Ensure Granola.ai is installed and has processed some meetings
ls -la ~/Library/Application\ Support/Granola/cache-v*.json

"uv command not found"

# Install uv
curl -LsSf https://astral.sh/uv/install.sh | sh

Server not appearing in Claude Desktop

  • Check Claude Desktop logs: ~/Library/Logs/Claude/mcp-server-granola.log

  • Restart Claude Desktop after config changes

Meeting notes appear empty

  • Granola sometimes stores rich notes inside documentPanels rather than notes_plain

  • This server reads those panels by default; set GRANOLA_PARSE_PANELS=0 to disable

Manual installation issues

These apply only if you installed from source (git clone) rather than via uvx.

"Permission denied" or "Operation not permitted"

  • This happens when the server is installed in ~/Documents or other protected macOS folders

  • Move the installation to your home directory:

    mv ~/Documents/granola-mcp-server ~/granola-mcp-server
    cd ~/granola-mcp-server
    uv sync

    Then update the path in claude_desktop_config.json

  • Or grant Claude Desktop Full Disk Access in System Settings > Privacy & Security

"Current directory does not exist"

  • This error occurs when using uv run with the --directory flag

  • Ensure the path in your Claude config points to the actual clone location

"Failed to spawn process" or "No such file or directory"

  • Run uv sync in the project directory to rebuild the venv

  • Verify the script exists: ls -la ~/granola-mcp-server/.venv/bin/granola-mcp-server

๐Ÿค Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository

  2. Create your feature branch (git checkout -b feature/amazing-feature)

  3. Commit your changes (git commit -m 'feat: add amazing feature')

  4. Push to the branch (git push origin feature/amazing-feature)

  5. Open a Pull Request

Please ensure your code follows the existing style and includes appropriate tests.

๐Ÿ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

Copyright (c) 2025 Proof+Geist

๐Ÿ™ Acknowledgments

  • Granola.ai for the amazing meeting intelligence app

  • Anthropic for Claude and the Model Context Protocol

  • Astral for the uv package manager


โš ๏ธ Disclaimer: This is an experimental project. Granola's cache format may change without notice. Use at your own risk.

A
license - permissive license
-
quality - not tested
B
maintenance

Maintenance

โ€“Maintainers
6dResponse time
3wRelease cycle
6Releases (12mo)
Issues opened vs closed

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/proofsh/granola-mcp-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server