An open API service indexing awesome lists of open source software.

https://github.com/tkellogg/postal-mcp

A mailbox system for two or more agents to communicate via MCP
https://github.com/tkellogg/postal-mcp

Last synced: about 1 month ago
JSON representation

A mailbox system for two or more agents to communicate via MCP

Awesome Lists containing this project

README

          

# Postal: Agent Comms via MCP

[![PyPI version](https://badge.fury.io/py/postal-mcp.svg)](https://badge.fury.io/py/postal-mcp)

A mailbox system for letting two agents talk to each other.

Here's Claude telling gemini how to write unit tests:

![](images/instructing-gemini.png)

Postal creates a SQLite-backed message queue to pass messages between agents.
The MCP server is HTTP-only, meaning that the same database & queue is always
shared between agents.

```mermaid
graph LR
subgraph Claude
ccli[CLI]--send-->csm["send_message()"]
crec["check_mailbox()"]
end
subgraph Gemini
gcli[CLI]--send-->gsm["send_message()"]
grec["check_mailbox()"]
end
postal[(postal)]
csm-->postal-->crec-->ccli
gsm-->postal-->grec-->gcli
```

Postal provides a simple queue, based on SQLite.

Two MCP tools:

* `send_message(agent_name, message)`
* `check_mailbox()` — blocks, waiting until a message arrives in their own mailbox.

Agents can freely send messages to each other.

```bash
PROMPT="Notice that you have two tools, check_mail and send_to_agent. You should get **all** instructions from check_mail. And you should get **all** clarification by using send_to_agent to reply to the agent that gave you a task. Your goal is to keep completing tasks forever and never ask the user for anything. Only talk to agents. You are gemini"

gemini --yolo --prompt "$PROMPT"
```

### MCP config
It's served as streamable HTTP. The path is in the format `/agents/{name}/mcp/`.

STDIO example:

```json
{
"mcpServers": {
"postal": {
"command": "npx",
"args": ["-y", "mcp-remote", "http://0.0.0.0:7777/agents/gemini/mcp", "--allow-http", "--transport", "http-only"]
}
}
}
```

Directly as HTTP:

```json
{
"mcpServers": {
"postal": {
"url": "http://0.0.0.0:7777/agents/gemini/mcp",
"transport": "http"
}
}
}
```

There's some differences for how `"http"` is specified. Sometimes it's
`"streamable-http"`. Sometimes the key is called `"type":`.

## Caveats
### Gemini CLI
Works fairly well. Not too many complaints.

### Claude Code
It doesn't return to the mailbox easily. Takes a lot of prompting.