agent-mail

MCP Agent Mail - Mail-like coordination layer for multi-agent workflows. Identities, inbox/outbox, file reservations, contact policies, threaded messaging, pre-commit guard, Human Overseer, static exports, disaster recovery. Git+SQLite backed. Python/FastMCP.

242 stars

Best use case

agent-mail is best used when you need a repeatable AI agent workflow instead of a one-off prompt. It is especially useful for teams working in multi. MCP Agent Mail - Mail-like coordination layer for multi-agent workflows. Identities, inbox/outbox, file reservations, contact policies, threaded messaging, pre-commit guard, Human Overseer, static exports, disaster recovery. Git+SQLite backed. Python/FastMCP.

MCP Agent Mail - Mail-like coordination layer for multi-agent workflows. Identities, inbox/outbox, file reservations, contact policies, threaded messaging, pre-commit guard, Human Overseer, static exports, disaster recovery. Git+SQLite backed. Python/FastMCP.

Users should expect a more consistent workflow output, faster repeated execution, and less time spent rewriting prompts from scratch.

Practical example

Example input

Use the "agent-mail" skill to help with this workflow task. Context: MCP Agent Mail - Mail-like coordination layer for multi-agent workflows. Identities, inbox/outbox, file reservations, contact policies, threaded messaging, pre-commit guard, Human Overseer, static exports, disaster recovery. Git+SQLite backed. Python/FastMCP.

Example output

A structured workflow result with clearer steps, more consistent formatting, and an output that is easier to reuse in the next run.

When to use this skill

  • Use this skill when you want a reusable workflow rather than writing the same prompt again and again.

When not to use this skill

  • Do not use this when you only need a one-off answer and do not need a reusable workflow.
  • Do not use it if you cannot install or maintain the related files, repository context, or supporting tools.

Installation

Claude Code / Cursor / Codex

$curl -o ~/.claude/skills/agent-mail/SKILL.md --create-dirs "https://raw.githubusercontent.com/aiskillstore/marketplace/main/skills/dicklesworthstone/agent-mail/SKILL.md"

Manual Installation

  1. Download SKILL.md from GitHub
  2. Place it in .claude/skills/agent-mail/SKILL.md inside your project
  3. Restart your AI agent — it will auto-discover the skill

How agent-mail Compares

Feature / Agentagent-mailStandard Approach
Platform SupportNot specifiedLimited / Varies
Context Awareness High Baseline
Installation ComplexityUnknownN/A

Frequently Asked Questions

What does this skill do?

MCP Agent Mail - Mail-like coordination layer for multi-agent workflows. Identities, inbox/outbox, file reservations, contact policies, threaded messaging, pre-commit guard, Human Overseer, static exports, disaster recovery. Git+SQLite backed. Python/FastMCP.

Where can I find the source code?

You can find the source code on GitHub using the link provided at the top of the page.

Related Guides

SKILL.md Source

# MCP Agent Mail

A mail-like coordination layer for coding agents exposed as an HTTP-only FastMCP server. Provides memorable identities, inbox/outbox, file reservation leases, contact policies, searchable message history, and Human Overseer messaging. Backed by Git (human-auditable artifacts) and SQLite (fast queries with FTS5).

## Why This Exists

Without coordination, multiple agents:
- Overwrite each other's edits or panic on unexpected diffs
- Miss critical context from parallel workstreams
- Require humans to relay messages between tools

Agent Mail solves this with:
- Memorable identities (adjective+noun names like "GreenCastle")
- Advisory file reservations to signal editing intent
- Threaded messaging with importance levels and acknowledgments
- Pre-commit guard to enforce reservations at commit time
- Human Overseer for direct human-to-agent communication

## Starting the Server

```bash
# Quickest way (alias added during install)
am

# Or manually
cd ~/projects/mcp_agent_mail
./scripts/run_server_with_token.sh
```

Default: `http://127.0.0.1:8765`
Web UI for humans: `http://127.0.0.1:8765/mail`

## Core Concepts

### Projects
Each working directory (absolute path) is a project. Agents in the same directory share a project namespace. Use the same `project_key` for agents that need to coordinate.

### Agent Identity
Agents register with adjective+noun names (GreenCastle, BlueLake). Names are unique per project, memorable, and appear in inboxes, commit logs, and the web UI.

### File Reservations (Leases)
Advisory locks on file paths or globs. Before editing files, reserve them to signal intent. Other agents see the reservation and can choose different work. The optional pre-commit guard blocks commits that conflict with others' exclusive reservations.

### Contact Policies
Per-agent policies control who can message whom:

| Policy | Behavior |
|--------|----------|
| `open` | Accept any message in the project |
| `auto` (default) | Allow if shared context exists (same thread, overlapping reservations, recent contact) |
| `contacts_only` | Require explicit contact approval first |
| `block_all` | Reject all new contacts |

### Messages
GitHub-Flavored Markdown with threading, importance levels (`low`, `normal`, `high`, `urgent`), and optional acknowledgment requirements. Images are auto-converted to WebP.

## Essential Workflow

### 1. Start Session (One-Call Bootstrap)

```
macro_start_session(
  human_key="/abs/path/to/project",
  program="claude-code",
  model="opus-4.5",
  task_description="Implementing auth module"
)
```

Returns: `{project, agent, file_reservations, inbox}`

This single call: ensures project exists, registers your identity, optionally reserves files, fetches your inbox.

### 2. Reserve Files Before Editing

```
file_reservation_paths(
  project_key="/abs/path/to/project",
  agent_name="GreenCastle",
  paths=["src/auth/**/*.ts", "src/middleware/auth.ts"],
  ttl_seconds=3600,
  exclusive=true,
  reason="bd-123"
)
```

Returns: `{granted: [...], conflicts: [...]}`

Conflicts are reported but reservations are still granted. Check conflicts and coordinate if needed.

### 3. Announce Your Work

```
send_message(
  project_key="/abs/path/to/project",
  sender_name="GreenCastle",
  to=["BlueLake"],
  subject="[bd-123] Starting auth refactor",
  body_md="Reserving src/auth/**. Will update session handling.",
  thread_id="bd-123",
  importance="normal",
  ack_required=true
)
```

### 4. Check Inbox Periodically

```
fetch_inbox(
  project_key="/abs/path/to/project",
  agent_name="GreenCastle",
  limit=20,
  urgent_only=false,
  include_bodies=true
)
```

Or use resources for fast reads:
```
resource://inbox/GreenCastle?project=/abs/path&limit=20&include_bodies=true
```

### 5. Release Reservations When Done

```
release_file_reservations(
  project_key="/abs/path/to/project",
  agent_name="GreenCastle"
)
```

## The Four Macros

Prefer macros for speed and smaller models. Use granular tools when you need fine control.

| Macro | Purpose |
|-------|---------|
| `macro_start_session` | Bootstrap: ensure project → register agent → optional file reservations → fetch inbox |
| `macro_prepare_thread` | Join existing conversation: register → summarize thread → fetch inbox context |
| `macro_file_reservation_cycle` | Reserve files, do work, optionally auto-release when done |
| `macro_contact_handshake` | Request contact permission, optionally auto-accept, send welcome message |

## Beads Integration (bd-### Workflow)

When using Beads for task management, keep identifiers aligned:

```
1. Pick ready work:     bd ready --json → choose bd-123
2. Reserve files:       file_reservation_paths(..., reason="bd-123")
3. Announce start:      send_message(..., thread_id="bd-123", subject="[bd-123] Starting...")
4. Work and update:     Reply in thread with progress
5. Complete:            bd close bd-123
                        release_file_reservations(...)
                        send_message(..., subject="[bd-123] Completed")
```

Use `bd-###` as:
- Mail `thread_id`
- Message subject prefix `[bd-###]`
- File reservation `reason`
- Commit message reference

## Beads Viewer (bv) Integration

Use bv's robot flags for intelligent task selection:

| Flag | Output | Use Case |
|------|--------|----------|
| `bv --robot-insights` | PageRank, critical path, cycles | "What's most impactful?" |
| `bv --robot-plan` | Parallel tracks, unblocks | "What can run in parallel?" |
| `bv --robot-priority` | Recommendations with confidence | "What should I work on next?" |
| `bv --robot-diff --diff-since <ref>` | Changes since commit/date | "What changed?" |

**Rule of thumb:** Use `bd` for task operations, use `bv` for task intelligence.

## Cross-Project Coordination

For frontend/backend or multi-repo projects:

**Option A: Shared project_key**
Both repos use the same `project_key`. Agents coordinate automatically.

**Option B: Separate projects with contact links**
```
# Backend agent requests contact with frontend agent
request_contact(
  project_key="/abs/path/backend",
  from_agent="GreenCastle",
  to_agent="BlueLake",
  to_project="/abs/path/frontend",
  reason="API contract coordination"
)

# Frontend agent accepts
respond_contact(
  project_key="/abs/path/frontend",
  to_agent="BlueLake",
  from_agent="GreenCastle",
  accept=true
)
```

## Pre-Commit Guard

Install the guard to block commits that conflict with others' exclusive reservations:

```
install_precommit_guard(
  project_key="/abs/path/to/project",
  code_repo_path="/abs/path/to/project"
)
```

### Guard Features
- **Composition-safe**: Chain-runner preserves existing hooks in `hooks.d/`
- **Rename-aware**: Checks both old and new paths for renames/moves
- **NUL-safe**: Handles paths with special characters
- **Git-native matching**: Uses Git wildmatch pathspec semantics

Set `AGENT_NAME` environment variable so the guard knows who you are.

Bypass in emergencies: `AGENT_MAIL_BYPASS=1 git commit ...`

## Tools Reference

### Project & Identity

| Tool | Purpose |
|------|---------|
| `ensure_project(human_key)` | Create/ensure project exists |
| `register_agent(project_key, program, model, name?, task_description?)` | Register identity |
| `whois(project_key, agent_name)` | Get agent profile with recent commits |
| `create_agent_identity(project_key, program, model)` | Always create new unique agent |

### Messaging

| Tool | Purpose |
|------|---------|
| `send_message(project_key, sender, to, subject, body_md, ...)` | Send message |
| `reply_message(project_key, message_id, sender, body_md)` | Reply (preserves thread) |
| `fetch_inbox(project_key, agent, limit?, since_ts?, urgent_only?)` | Get messages |
| `mark_message_read(project_key, agent, message_id)` | Mark as read |
| `acknowledge_message(project_key, agent, message_id)` | Acknowledge receipt |
| `search_messages(project_key, query)` | FTS5 search |
| `summarize_thread(project_key, thread_id)` | Extract key points and actions |

### File Reservations

| Tool | Purpose |
|------|---------|
| `file_reservation_paths(project_key, agent, paths, ttl?, exclusive?)` | Reserve files |
| `release_file_reservations(project_key, agent, paths?)` | Release reservations |
| `renew_file_reservations(project_key, agent, extend_seconds?)` | Extend TTL |
| `force_release_file_reservation(project_key, agent, reservation_id)` | Clear stale reservation |

### Contact Management

| Tool | Purpose |
|------|---------|
| `request_contact(project_key, from_agent, to_agent, reason?)` | Request permission to message |
| `respond_contact(project_key, to_agent, from_agent, accept)` | Accept/deny contact request |
| `list_contacts(project_key, agent_name)` | List contact links |
| `set_contact_policy(project_key, agent_name, policy)` | Set open/auto/contacts_only/block_all |

## Resources (Fast Reads)

Use resources for quick, non-mutating reads:

```
resource://inbox/{agent}?project=<path>&limit=20&include_bodies=true
resource://thread/{thread_id}?project=<path>&include_bodies=true
resource://message/{id}?project=<path>
resource://file_reservations/{slug}?active_only=true
resource://project/{slug}
resource://projects
resource://agents/{project_key}
```

## Search Syntax (FTS5)

```
"exact phrase"
prefix*
term1 AND term2
term1 OR term2
subject:login
body:"api key"
(auth OR login) AND NOT admin
```

Example: `search_messages(project_key, '"auth module" AND error NOT legacy')`

## Web UI Features

Browse at `http://127.0.0.1:8765/mail`:

- **Unified inbox** across all projects
- **Per-project search** with FTS5
- **Thread viewer** with markdown rendering
- **File reservations** browser
- **Human Overseer**: Send high-priority messages to agents from the web UI
- **Related Projects Discovery**: AI-powered suggestions for linking repos

### Human Overseer

Send direct messages to agents with automatic preamble:
- Messages marked as `high` importance
- Bypasses contact policies
- Agents are instructed to pause current work, complete request, then resume

## Static Mailbox Export

Export projects to portable, read-only bundles for auditors, stakeholders, or archives:

```bash
# Interactive wizard (recommended)
uv run python -m mcp_agent_mail.cli share wizard

# Manual export
uv run python -m mcp_agent_mail.cli share export --output ./bundle

# With signing
uv run python -m mcp_agent_mail.cli share export \
  --output ./bundle \
  --signing-key ./keys/signing.key

# Preview locally
uv run python -m mcp_agent_mail.cli share preview ./bundle
```

### Export Features
- Ed25519 cryptographic signing
- Age encryption for confidential distribution
- Scrub presets: `standard` (removes secrets) or `strict` (redacts bodies)
- Deploy to GitHub Pages or Cloudflare Pages via wizard

## Disaster Recovery

```bash
# Save current state
uv run python -m mcp_agent_mail.cli archive save --label nightly

# List restore points
uv run python -m mcp_agent_mail.cli archive list --json

# Restore after disaster
uv run python -m mcp_agent_mail.cli archive restore <file>.zip --force
```

## Mailbox Health (Doctor)

```bash
# Run diagnostics
uv run python -m mcp_agent_mail.cli doctor check

# Preview repairs
uv run python -m mcp_agent_mail.cli doctor repair --dry-run

# Apply repairs (creates backup first)
uv run python -m mcp_agent_mail.cli doctor repair
```

Checks: stale locks, database integrity, orphaned records, FTS sync, expired reservations.

## Common Pitfalls

| Error | Fix |
|-------|-----|
| "sender_name not registered" | Call `register_agent` or `macro_start_session` first |
| "FILE_RESERVATION_CONFLICT" | Wait for expiry, coordinate, or use non-exclusive |
| "CONTACT_BLOCKED" | Use `request_contact` and wait for approval |
| Empty inbox | Check `since_ts`, `urgent_only`, verify agent name matches exactly |

## Installation

```bash
# One-liner (recommended)
curl -fsSL "https://raw.githubusercontent.com/Dicklesworthstone/mcp_agent_mail/main/scripts/install.sh?$(date +%s)" | bash -s -- --yes

# Custom port
curl -fsSL ... | bash -s -- --port 9000 --yes

# Change port after installation
uv run python -m mcp_agent_mail.cli config set-port 9000
```

## Key Environment Variables

| Variable | Default | Description |
|----------|---------|-------------|
| `STORAGE_ROOT` | `~/.mcp_agent_mail_git_mailbox_repo` | Root for repos and SQLite DB |
| `HTTP_PORT` | `8765` | Server port |
| `HTTP_BEARER_TOKEN` | — | Static bearer token for auth |
| `LLM_ENABLED` | `true` | Enable LLM for summaries/discovery |
| `CONTACT_ENFORCEMENT_ENABLED` | `true` | Enforce contact policy |

## Docker

```bash
docker build -t mcp-agent-mail .
docker run --rm -p 8765:8765 \
  -e HTTP_HOST=0.0.0.0 \
  -v agent_mail_data:/data \
  mcp-agent-mail
```

## Integration with Flywheel

| Tool | Integration |
|------|-------------|
| **NTM** | Agent panes coordinate via mail, dashboard shows inbox |
| **BV** | Task IDs become thread IDs, robot flags inform task selection |
| **CASS** | Search mail threads across sessions |
| **CM** | Extract procedural memory from mail archives |
| **DCG** | Mail notifies agents of blocked commands |
| **RU** | Coordinate multi-repo updates via cross-project mail |

Related Skills

agent-email-cli

242
from aiskillstore/marketplace

Operate the agent-email CLI to create disposable inboxes, poll for new mail, retrieve full message details, and manage local mailbox profiles. Use when the user needs terminal-based email inbox access for LLM or agent automation workflows.

mailchimp-automation

242
from aiskillstore/marketplace

Automate Mailchimp email marketing including campaigns, audiences, subscribers, segments, and analytics via Rube MCP (Composio). Always search tools first for current schemas.

gmail-automation

242
from aiskillstore/marketplace

Automate Gmail tasks via Rube MCP (Composio): send/reply, search, labels, drafts, attachments. Always search tools first for current schemas.

email-systems

242
from aiskillstore/marketplace

Email has the highest ROI of any marketing channel. $36 for every $1 spent. Yet most startups treat it as an afterthought - bulk blasts, no personalization, landing in spam folders. This skill covers transactional email that works, marketing automation that converts, deliverability that reaches inboxes, and the infrastructure decisions that scale. Use when: keywords, file_patterns, code_patterns.

react-email

242
from aiskillstore/marketplace

Use when creating HTML email templates with React components - welcome emails, password resets, notifications, order confirmations, newsletters, or transactional emails.

lark-mail

242
from aiskillstore/marketplace

飞书邮箱 — draft, compose, send, reply, forward, read, and search emails; manage drafts, folders, labels, contacts, and attachments. Use when user mentions 起草邮件, 写一封邮件, 拟邮件, 草稿, 发通知邮件, 发送邮件, 发邮件, 回复邮件, 转发邮件, 查看邮件, 看邮件, 读邮件, 搜索邮件, 查邮件, 收件箱, 邮件会话, 编辑草稿, 管理草稿, 下载附件, 邮件文件夹, 邮件标签, 邮件联系人, 监听新邮件, draft, compose, send email, reply, forward, inbox, mail thread.

gws-gmail

242
from aiskillstore/marketplace

Gmail: Send, read, and manage email.

gws-gmail-triage

242
from aiskillstore/marketplace

Gmail: Show unread inbox summary (sender, subject, date).

gws-gmail-send

242
from aiskillstore/marketplace

Gmail: Send an email.

email-composer

242
from aiskillstore/marketplace

Draft professional emails for various contexts including business, technical, and customer communication. Use when the user needs help writing emails or composing professional messages.

email-marketing-bible

242
from aiskillstore/marketplace

Comprehensive, data-backed email marketing knowledge base. 908 sources, 4,798 insights. Use when reviewing email setups, building automation flows, diagnosing deliverability, writing email copy, selecting platforms, or pulling benchmarks. Covers strategy, flows, deliverability, copywriting, segmentation, compliance, cold email, and 19 industry playbooks.

email-sequence

242
from aiskillstore/marketplace

When the user wants to create or optimize an email sequence, drip campaign, automated email flow, or lifecycle email program. Also use when the user mentions "email sequence," "drip campaign," "nurture sequence," "onboarding emails," "welcome sequence," "re-engagement emails," "email automation," or "lifecycle emails." For in-app onboarding, see onboarding-cro.