Skip to main content

Your Granola meeting transcripts, saved locally. Automatically.

Project description

granola-saver

Your Granola meeting transcripts, saved locally. Automatically.

Granola transcribes your meetings beautifully - but transcripts live in a local cache that evicts after a few meetings. If you're on the free plan, notes older than 30 days disappear from the app entirely.

granola-saver watches for new meetings and saves each transcript as a clean markdown file the moment it ends. No cloud dependency, no API keys, no paid plan required.

Use with Claude Desktop

Add to your config (~/Library/Application Support/Claude/claude_desktop_config.json):

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

Restart Claude Desktop. Then ask Claude about your meetings:

  • "What meetings did I have this week?"
  • "Show me the transcript from my call with Sarah"
  • "Search my meetings for anything about the product launch"
  • "Export yesterday's standup to a file"

Available Tools

Tool What it does
list_meetings Browse recent meetings with metadata
get_transcript Read a full meeting transcript
search_meetings Search by title, attendee, or keyword
export_meeting Save a transcript as a markdown file
get_status Check cache and daemon status

Optional: Auto-Export Daemon

The MCP server gives you on-demand access through Claude. If you also want every meeting saved automatically as it ends, install the background daemon:

git clone https://github.com/adampaulwalker/granola-saver.git
cd granola-saver
bash install.sh

The installer will:

  • Ask where you'd like transcripts saved (default: ~/Granola Transcripts)
  • Set up a background daemon that starts automatically on login
  • Every meeting gets saved as a dated markdown file within 60 seconds of ending

Daemon Commands

# Check if the daemon is running
launchctl list | grep granola-saver

# View live logs
tail -f daemon.log

# Uninstall
bash uninstall.sh

Advanced: Folder Routing

Route transcripts to different folders based on attendee email domains or meeting title keywords. Edit routing-map.json:

{
  "email_domains": {
    "acme.com": "Acme Corp",
    "bigclient.io": "Big Client"
  },
  "title_keywords": {
    "standup": "Team/Standups",
    "interview": "Hiring"
  },
  "default_folder": ""
}

How it works

  1. Granola writes meeting data to a local cache file on your Mac
  2. granola-saver reads this cache to serve meeting data via MCP
  3. The optional daemon watches for changes using macOS native file events
  4. When a meeting ends, the transcript is extracted and saved as a dated markdown file

What you get

Every meeting saved as 2026-03-13-meeting-title.md with:

  • YAML frontmatter (title, date, duration, attendees)
  • Granola's AI-generated notes (if available)
  • Full timestamped transcript

Requirements

  • macOS (Granola's cache is macOS-only)
  • Python 3.10+
  • Granola (any plan, including free)

How is this different from Granola's MCP?

Granola's official MCP lets you query your meetings from AI tools. That's great for on-demand access, but it doesn't save anything locally.

granola-saver does both:

  • MCP server: Query your meetings from Claude Desktop (same as Granola's MCP)
  • Auto-export daemon: Saves every transcript as a local markdown file the moment your meeting ends (Granola doesn't do this)

Your transcripts live as plain files on your machine that you can search, back up, sync, or process however you want.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

granola_saver-1.4.1.tar.gz (83.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

granola_saver-1.4.1-py3-none-any.whl (19.7 kB view details)

Uploaded Python 3

File details

Details for the file granola_saver-1.4.1.tar.gz.

File metadata

  • Download URL: granola_saver-1.4.1.tar.gz
  • Upload date:
  • Size: 83.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for granola_saver-1.4.1.tar.gz
Algorithm Hash digest
SHA256 52079da189f44290b1ede45041925107629989de1076c1f49f638855614d8bfc
MD5 7834c58433ccfa40f136fb12c8935679
BLAKE2b-256 7ae3795b429df17801455a29c588d3ba4c09b06c2b7b87cde923a5bb22e98d1e

See more details on using hashes here.

File details

Details for the file granola_saver-1.4.1-py3-none-any.whl.

File metadata

  • Download URL: granola_saver-1.4.1-py3-none-any.whl
  • Upload date:
  • Size: 19.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for granola_saver-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a6b6cb3e0030e450b06b0cb9b5d620df720dc2189b5d8adafc44374afa2321f2
MD5 943618571c7c7d2da4f467749dcb7ff6
BLAKE2b-256 5754f23d44df11afed1c0f1cfc5159ffe0c24d8d8924121b1fc6afecc446ef2d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page