/install mails-for-agent
Email Skill — Agent Auth-Completion
You have the email address $MAILS_MAILBOX. Your primary superpower: complete service registrations autonomously by receiving verification codes via GET /api/code?timeout=60.
Make HTTP requests to $MAILS_API_URL with header Authorization: Bearer $MAILS_AUTH_TOKEN.
Sign up for a service: Fill form with $MAILS_MAILBOX → GET /api/code?timeout=60 → enter the code. Done.
API Endpoints
| Method | Endpoint | Description |
|---|---|---|
| GET | /api/inbox | List/search emails. Params: query, limit, offset, direction, label, mode (keyword/semantic/hybrid) |
| GET | /api/email?id=ID | Full email with body, attachments, labels |
| GET | /api/code?timeout=60 | Wait for verification code (long-poll). Params: timeout, since |
| POST | /api/send | Send email. Body: { from, to[], cc[], bcc[], subject, text, html, reply_to, in_reply_to, headers, attachments } |
| DELETE | /api/email?id=ID | Delete email and attachments |
| GET | /api/attachment?id=ID | Download attachment |
| GET | /api/threads | List conversation threads. Params: limit, offset |
| GET | /api/thread?id=ID | Get all emails in a thread |
| POST | /api/extract | Extract structured data. Body: { email_id, type } type: order/shipping/calendar/receipt/code |
| GET | /api/stats | Mailbox statistics (total, inbound, outbound, this month) |
| GET | /api/events | SSE real-time event stream. Params: types, since |
| GET | /api/mailbox | Mailbox info (status, webhook_url) |
| PATCH | /api/mailbox | Update mailbox settings. Body: { webhook_url } |
| PATCH | /api/mailbox/pause | Pause mailbox (blocks all operations) |
| PATCH | /api/mailbox/resume | Resume paused mailbox |
| GET | /api/mailbox/routes | List per-label webhook routes |
| PUT | /api/mailbox/routes | Upsert webhook route. Body: { label, webhook_url } |
| DELETE | /api/mailbox/routes?label=X | Delete webhook route for label |
| GET | /api/me | Mailbox info and capabilities |
| GET | /health | Health check (no auth) |
Request Format
All requests (except /health) require Authorization: Bearer $MAILS_AUTH_TOKEN header.
POST/PUT/PATCH requests require Content-Type: application/json header.
The to param is optional — the API auto-scopes to the token's mailbox.
Response Shapes
Inbox: { "emails": [{ "id", "from_address", "from_name", "subject", "code", "direction", "status", "received_at", "has_attachments", "attachment_count" }], "search_mode": "keyword" }
Email detail: Full email object with body_text, body_html, headers, metadata, labels, thread_id, in_reply_to, references, attachments[]
Code: { "id": "...", "code": "483920", "from": "...", "subject": "...", "received_at": "..." } or { "code": null }
Send: { "id": "...", "provider_id": "...", "thread_id": "..." }
Threads: { "threads": [{ "thread_id", "latest_email_id", "subject", "from_address", "from_name", "received_at", "message_count", "has_attachments" }] }
Stats: { "mailbox", "total_emails", "inbound", "outbound", "emails_this_month", "ingest": { "pending", "parsed", "failed" } }
Extract: { "email_id": "...", "extraction": { "type": "order", "order_id": "...", ... } }
Events (SSE): event: message.received\ data: { "email_id", "mailbox", "from", "subject", ... }
Send Fields
| Field | Required | Description |
|---|---|---|
| from | Yes | Must be $MAILS_MAILBOX (enforced server-side) |
| to | Yes | Array of recipients (max 50) |
| subject | Yes | Max 998 characters |
| text | text or html | Plain text body |
| html | text or html | HTML body |
| cc | No | Array of CC recipients |
| bcc | No | Array of BCC recipients |
| reply_to | No | Reply-to address |
| in_reply_to | No | Message-ID of parent email (enables threading) |
| headers | No | Custom headers object |
| attachments | No | [{ filename, content (base64), content_type?, content_id? }] |
Labels
Emails are auto-labeled on receive: newsletter, notification, code, personal. Filter with ?label=notification.
Common Flows
Sign up for a service: Fill form with $MAILS_MAILBOX → GET /api/code?timeout=60 → enter the code
Process inbox: GET /api/inbox → GET /api/email?id=ID → DELETE /api/email?id=ID
Reply to an email: GET /api/email?id=ID → POST /api/send with in_reply_to set to the email's message_id
View threads: GET /api/threads → GET /api/thread?id=THREAD_ID
Monitor in real-time: GET /api/events (SSE stream, reconnects automatically)
Extract data: POST /api/extract with {"email_id":"ID","type":"order"}
Set up webhook routing: PUT /api/mailbox/routes with {"label":"code","webhook_url":"https://..."}
Constraints
frommust match$MAILS_MAILBOX- Verification codes: 4-12 alphanumeric (EN/ZH/JA/KO)
- Code wait timeout max 55 seconds
- Send rate limit: 100 emails/day per mailbox
- Search uses FTS5 full-text search (keyword mode) or Vectorize (semantic mode)
- 确保已安装 OpenClaw(本地或 Docker 部署)
- 在对话框中输入安装命令:
/install mails-for-agent - 安装完成后,直接呼叫该 Skill 的名称或使用
/mails-for-agent触发 - 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
Mails for Agent 是什么?
Complete service registrations autonomously by receiving verification codes. Also: send and receive emails, monitor inbox, search by keyword, download attach... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 230 次。
如何安装 Mails for Agent?
在 OpenClaw 或 Claude Code 对话框中运行命令「/install mails-for-agent」即可一键安装,无需额外配置。
Mails for Agent 是免费的吗?
是的,Mails for Agent 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。
Mails for Agent 支持哪些平台?
Mails for Agent 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。
谁开发了 Mails for Agent?
由 Gene Dai(@digidai)开发并维护,当前版本 v1.8.0。