thunderbird-mcp
Provides tools for searching and reading Thunderbird emails, including full-text search, retrieving threads, messages, folders, accounts, and stats, using Thunderbird's local index without requiring IMAP credentials.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@thunderbird-mcpFind emails from John about the budget report"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
thunderbird-mcp
A read-only MCP server that lets an LLM search and read your Thunderbird email — locally, with no IMAP connection and no credentials.
It works by querying Thunderbird's own full-text index (GLODA, the
global-messages-db.sqlite that Thunderbird already maintains). The server takes
an atomic snapshot of that database and exposes a handful of focused tools to any
MCP client: Claude Desktop, Claude Code, or the Agent SDK.
You: "What did the vendor say about the shipment quote last month?"
LLM: → tb_search(query="shipment quote", since="2024-01-01")
→ tb_thread(conversation_id=…)
"They approved it on Jan 11 and attached po.pdf. Here's the thread…"Why
Most "email + LLM" integrations log into your IMAP server, re-download everything, and need an app password. This one doesn't move any mail or hold any secret. Thunderbird has already indexed every message you have — including local folders and archived accounts — so the fastest, safest path is to read that index directly.
No credentials. Nothing to configure, nothing to leak. Read-only by design.
Offline. Searches your local index; works on a plane.
Whole history. Every account and local folder Thunderbird knows about, in one place.
Cross-platform. Auto-detects your profile on Linux, macOS and Windows (including running under WSL against a Windows install).
Related MCP server: mu-mcp
Tools
Tool | What it does |
| Full-text + header + date search, newest first |
| Every message to/from a contact or domain |
| A full conversation, oldest first |
| One message with its complete body |
| All folders with per-folder message counts |
| Configured accounts and their IMAP servers |
| Total indexed messages and their date range |
Install
Requires Python 3.11+ and a local Thunderbird install.
git clone https://github.com/agimenez-dev/thunderbird-mcp
cd thunderbird-mcp
uv sync # or: pip install -e .Use with Claude Desktop / Claude Code
Add the server to your MCP config (claude_desktop_config.json, or .mcp.json
for Claude Code):
{
"mcpServers": {
"thunderbird": {
"command": "uv",
"args": ["--directory", "/path/to/thunderbird-mcp", "run", "thunderbird-mcp"]
}
}
}Restart the client and ask it about your mail.
Configuration
The server auto-detects the default Thunderbird profile. Override it when Thunderbird lives elsewhere — for example, querying a Windows install from WSL:
export THUNDERBIRD_PROFILE="/mnt/c/Users/You/AppData/Roaming/Thunderbird/Profiles/xxxx.default-release"THUNDERBIRD_PROFILE must point at the profile directory — the folder that
contains global-messages-db.sqlite.
How it works
Thunderbird
└─ <profile>/global-messages-db.sqlite (GLODA full-text index, WAL mode)
│
│ snapshot.py — SQLite online-backup API (read-only + immutable),
│ atomic publish, retries on lock. Refreshes lazily (>15 min old).
▼
~/.cache/thunderbird-mcp/snapshot.sqlite (read-only copy)
│
│ db.py — LIKE queries over messagesText_content
▼
server.py — FastMCP, 7 toolsTwo implementation notes worth knowing:
Why a snapshot? Thunderbird keeps the index open in WAL mode. Reading it live risks a
database is lockederror or an inconsistent read, so the server copies it with SQLite's online-backup API before querying — never touching the original.Why
LIKEinstead of FTS? GLODA's full-text table uses a custommozportertokenizer that isn't compiled into a standard Pythonsqlite3. Rather than ship a patched SQLite, the server queries the precomputed text columns GLODA already maintains (c0body,c1subject, …) withLIKE.
What it deliberately does not do
Send, move, delete or modify mail. Read-only, full stop.
Touch IMAP or store any credential.
Re-index. It trusts the index Thunderbird already keeps current.
Return attachment binaries — only their file names.
Development
uv sync --extra dev
uv run pytest # query + parsing layers are covered without Thunderbird installed
uv run ruff check .License
MIT — see LICENSE.
This server cannot be installed
Maintenance
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/agimenez-dev/thunderbird-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server