/install agent-mailbox-light
Agent Mailbox
Use this skill for a very lightweight internal mail system between OpenClaw agent workspaces.
Design goals
- No central registry
- No guaranteed delivery
- No push notifications
- No group-message storms
- Best-effort fanout only
- Per-workspace local inboxes
- Token-efficient reads: each agent reads only its own inbox
- Advisory context only, not an execution bus
- Local filesystem only, not cloud sync or webhook delivery
This is a middle layer between long-term memory and chat messaging.
Safety boundary
This skill is intentionally narrow.
It is for local mailbox-style context sharing only.
It does not implement:
- automatic task execution
- autonomous task dispatch
- webhook callbacks
- remote sync
- cloud delivery
- receipt tracking
- retry queues
Mailbox items should be treated as advisory hints for local agent judgment, not commands that must be executed.
Mailbox location
Each workspace owns its own local mailbox under:
\x3Cworkspace>/.agent-mailbox/
Subdirectories:
inbox/— unread or pending mail filesarchive/— consumed mail files
Examples:
/path/to/workspace/.agent-mailbox/inbox//path/to/another-workspace/.agent-mailbox/inbox/
Fanout model
Sender scripts scan candidate workspaces using a configurable glob pattern.
Default pattern:
$HOME/.openclaw/workspace*
Override with MAILBOX_GLOB when your workspaces live elsewhere.
If a workspace contains .agent-mailbox/inbox/, write a mail file there.
If the path does not exist or write fails, skip it.
Do not maintain a registry. Do not retry failed deliveries. Do not block on partial failure.
File model
One mail = one file.
Filename format:
\x3Cstamp>--\x3Csender>--\x3Cpriority>--\x3Cslug>.md
Example:
20260322100000--main--warn--cron-list-broken.md
Fields:
stamp—YYYYMMDDHHMMSSsender— short sender idpriority—info,warn, orcriticalslug— short readable identifier
Mail content
Use a short header followed by a blank line and body.
Example:
Title: cron list 异常
From: main
Created-At: 2026-03-22T10:00:00+08:00
Priority: warn
Tags: cron,ops
`openclaw cron list` 当前报错,先不要依赖其输出。
建议改用:
- openclaw cron status
- openclaw cron runs
Baseline integration
For best results, integrate mailbox checking into the agent's baseline startup or task-entry workflow.
Recommended baseline rule:
- If
.agent-mailbox/inbox/exists in the current workspace, check only the newest 1-3 mail files before normal task work - Read only enough to determine relevance
- Compress relevant mail into a very short working summary
- Archive processed mail immediately so inbox stays small
- Do not rebroadcast, auto-reply, or auto-write all mail into long-term memory
This makes the mailbox reliable in practice while keeping token cost low.
Read flow
When loading this skill in a workspace:
- Ensure the local mailbox exists
- List files in local
inbox/ - Read only the newest few files you need
- Summarize them briefly into context
- Decide whether to ignore, use for this session, or adopt into memory
- Archive or delete consumed mail so it is not repeatedly re-read
Prefer reading only 1–5 newest mails.
Receiver handling policy
Treat mailbox items as single-consumption lightweight context hints.
Default handling:
- Read the newest relevant mail
- Compress it into a very short summary for the current task
- Decide whether it matters only for this turn or should affect longer-lived memory
- Archive it after processing so it leaves the inbox
Recommended decision model:
critical— read first; usually affect current behavior immediatelywarn— read and adopt when relevant to current workinfo— skim quickly; keep only if useful
Possible outcomes after reading:
- Ignore — not relevant; archive it
- Session-use only — use it for the current turn/session; archive it
- Adopt to memory — if it represents a durable fact, explicitly write the distilled version into the proper memory file; then archive it
- Act now — if it changes current execution, apply it and archive it
Do not automatically:
- rebroadcast mail
- reply to the sender through chat
- write all mail into long-term memory
- keep already-processed mail in
inbox/
Inbox should contain only unprocessed mail. Archive should contain processed mail.
Archive policy
Default: archive after reading, do not keep re-reading inbox mail.
Archive path:
\x3Cworkspace>/.agent-mailbox/archive/
This keeps the inbox small and token cost low.
Good uses
- low-noise cross-agent operational note
- temporary warning for other workspaces
- lightweight fanout without chat delivery
- “FYI only” advisory
- coordination hint that does not belong in long-term memory yet
- local best-effort sharing of small, non-urgent context
Avoid
- secrets unless truly necessary
- large documents
- durable memory that belongs in MEMORY.md or memory/YYYY-MM-DD.md
- real-time urgent alerts that should use actual messaging
- any design that assumes guaranteed delivery
- any design that expects mailbox files to trigger automatic execution
- any claim of cloud sync, webhook transport, or remote callback support
Recommended AGENTS.md snippet
You can paste this into a workspace's AGENTS.md:
### 📬 Lightweight Mailbox Check
If this workspace has `.agent-mailbox/inbox/`, do a **very light mailbox check** before starting normal task work:
1. Look at only the newest **1-3** mail files
2. Read only what is needed to identify relevance
3. Compress relevant mail into a very short working summary
4. Archive processed mail so inbox stays small
5. Do **not** rebroadcast, auto-reply, or dump all mail into long-term memory
Think of mailbox items as lightweight internal coordination hints, not chat messages and not permanent memory.
Minimal receive command pattern
Use this minimal pattern when an agent wants to consume mailbox items manually from shell.
This pattern is intentionally local and conservative: inspect, summarize, archive. It should not be extended into automatic execution of mailbox contents.
MAIL=$(./skills/agent-mailbox/scripts/list-mailbox.sh . 1 | head -n 1)
if [ -n "$MAIL" ]; then
sed -n '1,40p' "$MAIL"
./skills/agent-mailbox/scripts/archive-mailbox.sh "$MAIL" >/dev/null
fi
Use this behavior convention:
- check only the newest mail first
- read only enough to judge relevance
- archive immediately after processing
- keep inbox small
If you need a slightly broader pass, read up to 3 mails:
./skills/agent-mailbox/scripts/list-mailbox.sh . 3
Scripts
Use bundled scripts when possible:
scripts/init-mailbox.sh— initialize a mailbox in a workspacescripts/send-mailbox.sh— fan out mail to mailbox-enabled workspacesscripts/list-mailbox.sh— list local inbox mailscripts/archive-mailbox.sh— archive a consumed mail filescripts/cleanup-mailbox.sh— prune old archive files
Read the script directly if you need to inspect or change behavior.
- Make sure OpenClaw is installed (local or Docker)
- Run the install command in chat:
/install agent-mailbox-light - After installation, invoke the skill by name or use
/agent-mailbox-light - Provide required inputs per the skill's parameter spec and get structured output
What is Agent Mailbox Light?
Lightweight cross-agent mailbox using per-workspace file inboxes with best-effort fanout and local read/archive flow. Use when you want a middle layer betwee... It is an AI Agent Skill for Claude Code / OpenClaw, with 149 downloads so far.
How do I install Agent Mailbox Light?
Run "/install agent-mailbox-light" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.
Is Agent Mailbox Light free?
Yes, Agent Mailbox Light is completely free, licensed under MIT-0. You can download, install and use it at no cost.
Which platforms does Agent Mailbox Light support?
Agent Mailbox Light is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).
Who created Agent Mailbox Light?
It is built and maintained by Meng Yang (@yangmeng6666); the current version is v1.0.1.