Install
openclaw skills install email-send-receive-tool通过 IMAP/SMTP 连接个人邮箱,支持完整邮件收发、抄送、附件、HTML、收件箱检索与附件下载;是当前邮件体系中唯一的个人邮箱主通道。
openclaw skills install email-send-receive-tool加载本 skill 后,无论任何情况,第一步必须立即调用 get-token.sh 获取凭证。 不要检查 .env,不要读取任何配置文件,不要判断是否已配置——直接执行凭证获取脚本。脚本内部会自动从凭证服务拉取授权码、推断 IMAP/SMTP 服务器并写入 .env。
如果用户指定了邮箱(如 test@163.com),从邮箱 @ 后的域名推断 platform 参数:
| platform 参数 | 对应邮箱域名 |
|---|---|
163_mail | 163.com, vip.163.com, 126.com, vip.126.com, 188.com, vip.188.com, yeah.net |
qq_mail | qq.com, foxmail.com, vip.qq.com, exmail.qq.com |
gmail | gmail.com |
outlook | outlook.com, hotmail.com, live.com, live.cn |
sina_mail | sina.com, sina.cn, vip.sina.com |
sohu_mail | sohu.com |
然后调用:
bash '<SCRIPT_PATH>/get-token.sh' --platform '<平台名>'powershell -ExecutionPolicy Bypass -File '<SCRIPT_PATH>\get-token.ps1' -Platform '<平台名>'如果用户未指定邮箱,不传 --platform 参数,脚本会自动遍历所有平台找到第一个可用的:
bash '<SCRIPT_PATH>/get-token.sh'其中 <SCRIPT_PATH> 指本 skill(imap-smtp-email)的根目录。
脚本成功后会输出 JSON(含 "success": true、"email": "xxx")并将凭证写入 .env。
凭证就绪后,通过 resolve-account.cjs 执行实际邮件操作:
node '<SCRIPT_PATH>/scripts/resolve-account.cjs' send \
--account-email 'test@163.com' \
--to 'recipient@example.com' \
--subject 'Hello' \
--body 'World'
node '<SCRIPT_PATH>/scripts/resolve-account.cjs' inbox-check \
--account-email 'test@163.com'
支持两种方式指定使用哪个邮箱:
--account-email 'your@163.com'--account-platform 'sina_mail'中文别名映射表(LLM 必读):当用户消息中包含以下关键词但未给出精确邮箱地址时,使用 --account-platform 参数:
| 用户说法(关键词) | --account-platform 值 |
|---|---|
| 新浪邮箱、新浪、sina | sina_mail |
| 网易邮箱、163邮箱、163、126邮箱、netease | 163_mail |
| QQ邮箱、QQ、foxmail、腾讯邮箱 | qq_mail |
| Gmail、谷歌邮箱、谷歌、google | gmail |
| Outlook、微软邮箱、微软、hotmail | outlook |
| 搜狐邮箱、搜狐、sohu | sohu_mail |
示例:用户说"用新浪邮箱帮我发个邮件"→
node '<SCRIPT_PATH>/scripts/resolve-account.cjs' send \
--account-platform 'sina_mail' \
--to 'recipient@example.com' \
--subject 'Hello' \
--body 'World'
优先级:
--account-email>--account-platform> 自动选择
.env 文件定位:这是唯一的个人邮箱主 skill。只要需求不再是"推送到我自己的邮箱做留存",而是要像正常邮箱一样完整收发邮件,就应该走
imap-smtp-email。
imap-smtp-email 负责所有完整邮件能力:
to / cc / bcc当前邮件体系中,所有个人邮箱能力都统一收敛到本 skill,不再按邮箱厂商拆分入口。
| 问题 | 平台公邮 | imap-smtp-email |
|---|---|---|
| 推送到自己的邮箱 | ✅ | ✅ |
| 发给别人 | ❌ | ✅ |
| 抄送 / 密送 | ❌ | ✅ |
| HTML | ❌ | ✅ |
| 附件 | ❌ | ✅ |
| 收件 / 搜索 / 下载附件 | ❌ | ✅ |
| 零配置 | ✅ | ❌ |
判断口诀:
imap-smtp-email这里的关键不是"先检查平台公邮",而是先理解场景:如果任务本质是结果留存,就选平台公邮;如果任务本质是完整邮件动作,就直接选本 skill。
本 skill 统一承接了个人邮箱场景里仍然有效的能力与预设:
get-token.sh / get-token.ps1)这意味着:
email-skill 的个人邮箱分流目标只剩一个:imap-smtp-email以下 provider 已内置到 setup.sh 配置向导中:
| Provider | IMAP Host | IMAP Port | SMTP Host | SMTP Port |
|---|---|---|---|---|
| 163.com | imap.163.com | 993 | smtp.163.com | 465 |
| vip.163.com | imap.vip.163.com | 993 | smtp.vip.163.com | 465 |
| 126.com | imap.126.com | 993 | smtp.126.com | 465 |
| vip.126.com | imap.vip.126.com | 993 | smtp.vip.126.com | 465 |
| 188.com | imap.188.com | 993 | smtp.188.com | 465 |
| vip.188.com | imap.vip.188.com | 993 | smtp.vip.188.com | 465 |
| yeah.net | imap.yeah.net | 993 | smtp.yeah.net | 465 |
| gmail.com | imap.gmail.com | 993 | smtp.gmail.com | 587 |
| Outlook.com | outlook.office365.com | 993 | smtp-mail.outlook.com | 587 |
| qq.com | imap.qq.com | 993 | smtp.qq.com | 465 |
| foxmail.com | imap.qq.com | 993 | smtp.qq.com | 465 |
| yahoo.com | imap.mail.yahoo.com | 993 | smtp.mail.yahoo.com | 465 |
| sina.com | imap.sina.com | 993 | smtp.sina.com | 465 |
| sohu.com | imap.sohu.com | 993 | smtp.sohu.com | 465 |
| 139.com | imap.139.com | 993 | smtp.139.com | 465 |
| exmail.qq.com | imap.exmail.qq.com | 993 | smtp.exmail.qq.com | 465 |
| aliyun.com | imap.aliyun.com | 993 | smtp.aliyun.com | 465 |
| Custom | 自定义 | 自定义 | 自定义 | 自定义 |
对于
587端口,SMTP_SECURE=false,走 STARTTLS。 对于465端口,SMTP_SECURE=true,走 SSL。
入口脚本内部自动完成以下步骤,无需任何手动操作:
--account-email 参数或自动选择决定使用哪个邮箱
<SCRIPT_PATH>指本 skill(imap-smtp-email)的根目录。
inbox-checkbash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' inbox-check \
--account-email 'your@163.com' --limit 10 --mailbox INBOX --recent 2h
inbox-searchbash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' inbox-search \
--account-email 'your@163.com' --subject 发票 --recent 7d --limit 20
inbox-fetchbash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' inbox-fetch \
--account-email 'your@163.com' 12345 --mailbox INBOX
inbox-downloadbash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' inbox-download \
--account-email 'your@163.com' 12345 --dir "$HOME/Downloads"
bash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' inbox-mark-read --account-email 'your@163.com' 12345
bash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' inbox-mark-unread --account-email 'your@163.com' 12345
bash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' inbox-list-mailboxes --account-email 'your@163.com'
sendbash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' send \
--account-email 'your@163.com' \
--to partner@example.com \
--subject "Hello" \
--body "World"
bash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' send \
--account-email 'your@163.com' \
--to recipient@example.com \
--subject "周报" \
--html \
--body "<h1>Weekly Report</h1><p>详情见正文</p>"
bash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' send \
--account-email 'your@163.com' \
--to recipient@example.com \
--subject "报告" \
--body "请查收附件" \
--attach /Users/you/Documents/report.pdf
bash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' send \
--account-email 'your@163.com' \
--to a@example.com \
--cc b@example.com \
--bcc c@example.com \
--subject "项目同步" \
--body "请查收"
email-skill:统一入口,负责意图识别与路由分发public-skill:平台公邮,仅做"推送到自己邮箱"imap-smtp-email(本 skill):完整个人邮箱能力参见顶部「⚠️ 强制首步」段落。所有邮件操作必须且只能通过入口脚本执行。