IMAP / SMTP Email(个人邮箱主 Skill)
⚠️ 强制首步(最高优先级,必读必执行)
加载本 skill 后,无论任何情况,第一步必须立即调用 get-token.sh 获取凭证。 不要检查 .env,不要读取任何配置文件,不要判断是否已配置——直接执行凭证获取脚本。脚本内部会自动从凭证服务拉取授权码、推断 IMAP/SMTP 服务器并写入 .env。
第 1 步:获取凭证(必须先执行)
如果用户指定了邮箱(如 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 |
然后调用:
- macOS / Linux:
bash '<SCRIPT_PATH>/get-token.sh' --platform '<平台名>' - Windows:
powershell -ExecutionPolicy Bypass -File '<SCRIPT_PATH>\get-token.ps1' -Platform '<平台名>'
如果用户未指定邮箱,不传 --platform 参数,脚本会自动遍历所有平台找到第一个可用的:
- macOS / Linux:
bash '<SCRIPT_PATH>/get-token.sh'
其中 <SCRIPT_PATH> 指本 skill(imap-smtp-email)的根目录。
脚本成功后会输出 JSON(含 "success": true、"email": "xxx")并将凭证写入 .env。
第 2 步:执行邮件命令
凭证就绪后,通过 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> 自动选择
禁止事项(违反将导致任务失败)
- ❌ 禁止跳过第 1 步直接执行邮件命令
- ❌ 禁止手动读取或修改
.env文件 - ❌ 禁止在获取凭证前做任何"配置检查"或"环境检查"
- ❌ 禁止告诉用户"需要先配置"或"需要授权"——凭证由脚本自动获取
定位:这是唯一的个人邮箱主 skill。只要需求不再是"推送到我自己的邮箱做留存",而是要像正常邮箱一样完整收发邮件,就应该走
imap-smtp-email。
1. 现在的职责
imap-smtp-email 负责所有完整邮件能力:
- 发给任意收件人
to/cc/bcc- 纯文本 / HTML
- 附件发送
- IMAP 收件、搜索、查看详情
- 下载附件
- 标记已读 / 未读
- 列出邮箱文件夹
当前邮件体系中,所有个人邮箱能力都统一收敛到本 skill,不再按邮箱厂商拆分入口。
2. 与平台公邮的边界
| 问题 | 平台公邮 | imap-smtp-email |
|------|----------|-------------------|
| 推送到自己的邮箱 | ✅ | ✅ |
| 发给别人 | ❌ | ✅ |
| 抄送 / 密送 | ❌ | ✅ |
| HTML | ❌ | ✅ |
| 附件 | ❌ | ✅ |
| 收件 / 搜索 / 下载附件 | ❌ | ✅ |
| 零配置 | ✅ | ❌ |
判断口诀:
- 只给自己做留存:更适合平台公邮
- 像正常邮箱那样收发:直接
imap-smtp-email
这里的关键不是"先检查平台公邮",而是先理解场景:如果任务本质是结果留存,就选平台公邮;如果任务本质是完整邮件动作,就直接选本 skill。
3. 收敛后的能力组成
本 skill 统一承接了个人邮箱场景里仍然有效的能力与预设:
- 网易系邮箱 provider 预设
- QQ / Foxmail / 企业邮 provider 预设
- 统一的凭证自动刷新脚本(
get-token.sh/get-token.ps1)
这意味着:
email-skill的个人邮箱分流目标只剩一个:imap-smtp-email- 个人邮箱侧的脚本、配置和帮助信息都应围绕本 skill 维护
4. 支持的邮箱 Provider 预设
以下 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。
5. 凭证与配置(全自动)
入口脚本内部自动完成以下步骤,无需任何手动操作:
- 调 4230 接口查询已绑定的所有个人邮箱
- 根据
--account-email参数或自动选择决定使用哪个邮箱 - 自动刷新凭证并写入配置
- 然后执行后续的 smtp / imap 命令
7. IMAP 命令
<SCRIPT_PATH>指本 skill(imap-smtp-email)的根目录。
inbox-check
bash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' inbox-check \
--account-email 'your@163.com' --limit 10 --mailbox INBOX --recent 2h
inbox-search
bash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' inbox-search \
--account-email 'your@163.com' --subject 发票 --recent 7d --limit 20
inbox-fetch
bash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' inbox-fetch \
--account-email 'your@163.com' 12345 --mailbox INBOX
inbox-download
bash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' inbox-download \
--account-email 'your@163.com' 12345 --dir "$HOME/Downloads"
其他 IMAP 命令
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'
8. SMTP 命令
send
bash '<SCRIPT_PATH>/scripts/unix/email_gateway.sh' send \
--account-email 'your@163.com' \
--to partner@example.com \
--subject "Hello" \
--body "World"
常见示例
发送 HTML 邮件
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 "请查收"
9. 与其他 skill 的关系
email-skill:统一入口,负责意图识别与路由分发public-skill:平台公邮,仅做"推送到自己邮箱"imap-smtp-email(本 skill):完整个人邮箱能力
10. 调用规范
参见顶部「⚠️ 强制首步」段落。所有邮件操作必须且只能通过入口脚本执行。
Scan to join WeChat group