Skills imap-smtp-email
Read and send email via IMAP/SMTP. Check for new/unread messages, fetch content, search mailboxes, mark as read/unread, and send emails with attachments. Supports multiple accounts. Works with any IMAP/SMTP server including Gmail, Outlook, 163.com, vip.163.com, 126.com, vip.126.com, 188.com, and vip.188.com.
git clone https://github.com/openclaw/skills
T=$(mktemp -d) && git clone --depth=1 https://github.com/openclaw/skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/arry8/imap-smtp-email-fixed" ~/.claude/skills/openclaw-skills-imap-smtp-email-ff7077 && rm -rf "$T"
T=$(mktemp -d) && git clone --depth=1 https://github.com/openclaw/skills "$T" && mkdir -p ~/.openclaw/skills && cp -r "$T/skills/arry8/imap-smtp-email-fixed" ~/.openclaw/skills/openclaw-skills-imap-smtp-email-ff7077 && rm -rf "$T"
skills/arry8/imap-smtp-email-fixed/SKILL.mdIMAP/SMTP Email Tool
Read, search, and manage email via IMAP protocol. Send email via SMTP. Supports Gmail, Outlook, 163.com, vip.163.com, 126.com, vip.126.com, 188.com, vip.188.com, and any standard IMAP/SMTP server.
Configuration
Run the setup script to configure your email account:
bash setup.sh
Configuration is split into two files:
(skill directory) — server hosts, ports, TLS settings, allowed dirsconfig.env
— credentials (user, password, from address)~/.openclaw/.env
Legacy fallback:
~/.config/imap-smtp-email/.env (single combined file).
Config file format
# Default account (no prefix) IMAP_HOST=imap.gmail.com IMAP_PORT=993 IMAP_USER=your@email.com IMAP_PASS=your_password IMAP_TLS=true IMAP_REJECT_UNAUTHORIZED=true IMAP_MAILBOX=INBOX SMTP_HOST=smtp.gmail.com SMTP_PORT=587 SMTP_SECURE=false SMTP_USER=your@email.com SMTP_PASS=your_password SMTP_FROM=your@email.com SMTP_REJECT_UNAUTHORIZED=true # File access whitelist (security) ALLOWED_READ_DIRS=~/Downloads,~/Documents ALLOWED_WRITE_DIRS=~/Downloads
Multi-Account
You can configure additional email accounts in the same config file. Each account uses a name prefix (uppercase) on all variables.
Adding an account
Run the setup script and choose "Add a new account":
bash setup.sh
Or manually add prefixed config to
config.env and secrets to ~/.openclaw/.env:
# Work account (WORK_ prefix) WORK_IMAP_HOST=imap.company.com WORK_IMAP_PORT=993 WORK_IMAP_USER=me@company.com WORK_IMAP_PASS=password WORK_IMAP_TLS=true WORK_IMAP_REJECT_UNAUTHORIZED=true WORK_IMAP_MAILBOX=INBOX WORK_SMTP_HOST=smtp.company.com WORK_SMTP_PORT=587 WORK_SMTP_SECURE=false WORK_SMTP_USER=me@company.com WORK_SMTP_PASS=password WORK_SMTP_FROM=me@company.com WORK_SMTP_REJECT_UNAUTHORIZED=true
Using a named account
Add
--account <name> before the command:
node scripts/imap.js --account work check node scripts/smtp.js --account work send --to foo@bar.com --subject Hi --body Hello
Without
--account, the default (unprefixed) account is used.
Account name rules
- Letters and digits only (e.g.,
,work
,163
)personal2 - Case-insensitive:
andwork
refer to the same accountWORK - The prefix in
is always uppercase (e.g.,.env
)WORK_IMAP_HOST
andALLOWED_READ_DIRS
are shared across all accounts (always unprefixed)ALLOWED_WRITE_DIRS
Common Email Servers
| 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 | imap.gmail.com | 993 | smtp.gmail.com | 587 |
| Yahoo Mail | imap.mail.yahoo.com | 993 | smtp.mail.yahoo.com | 465 |
| Outlook | outlook.office365.com | 993 | smtp.office365.com | 587 |
| QQ Mail | imap.qq.com | 993 | smtp.qq.com | 587 |
Important for Gmail:
- Gmail does not accept your regular account password
- You must generate an App Password: https://myaccount.google.com/apppasswords
- Use the generated 16-character App Password as
/IMAP_PASSSMTP_PASS - Requires Google Account with 2-Step Verification enabled
Important for 163.com:
- Use authorization code (授权码), not account password
- Enable IMAP/SMTP in web settings first
IMAP Commands (Receiving Email)
check
Check for new/unread emails.
node scripts/imap.js [--account <name>] check [--limit 10] [--mailbox INBOX] [--recent 2h]
Options:
: Max results (default: 10)--limit <n>
: Mailbox to check (default: INBOX)--mailbox <name>
: Only show emails from last X time (e.g., 30m, 2h, 7d)--recent <time>
fetch
Fetch full email content by UID.
node scripts/imap.js [--account <name>] fetch <uid> [--mailbox INBOX]
download
Download all attachments from an email, or a specific attachment.
node scripts/imap.js [--account <name>] download <uid> [--mailbox INBOX] [--dir <path>] [--file <filename>]
Options:
: Mailbox (default: INBOX)--mailbox <name>
: Output directory (default: current directory)--dir <path>
: Download only the specified attachment (default: download all)--file <filename>
search
Search emails with filters.
node scripts/imap.js [--account <name>] search [options] Options: --unseen Only unread messages --seen Only read messages --from <email> From address contains --subject <text> Subject contains --recent <time> From last X time (e.g., 30m, 2h, 7d) --since <date> After date (YYYY-MM-DD) --before <date> Before date (YYYY-MM-DD) --limit <n> Max results (default: 20) --mailbox <name> Mailbox to search (default: INBOX)
mark-read / mark-unread
Mark message(s) as read or unread.
node scripts/imap.js [--account <name>] mark-read <uid> [uid2 uid3...] node scripts/imap.js [--account <name>] mark-unread <uid> [uid2 uid3...]
list-mailboxes
List all available mailboxes/folders.
node scripts/imap.js [--account <name>] list-mailboxes
list-accounts
List all configured email accounts.
node scripts/imap.js list-accounts node scripts/smtp.js list-accounts
Shows account name, email address, server addresses, and configuration status.
SMTP Commands (Sending Email)
send
Send email via SMTP.
node scripts/smtp.js [--account <name>] send --to <email> --subject <text> [options]
Required:
: Recipient (comma-separated for multiple)--to <email>
: Email subject, or--subject <text>--subject-file <file>
Optional:
: Plain text body--body <text>
: Send body as HTML--html
: Read body from file--body-file <file>
: Read HTML from file--html-file <file>
: CC recipients--cc <email>
: BCC recipients--bcc <email>
: Attachments (comma-separated)--attach <file>
: Override default sender--from <email>
Examples:
# Simple text email node scripts/smtp.js send --to recipient@example.com --subject "Hello" --body "World" # HTML email node scripts/smtp.js send --to recipient@example.com --subject "Newsletter" --html --body "<h1>Welcome</h1>" # Email with attachment node scripts/smtp.js send --to recipient@example.com --subject "Report" --body "Please find attached" --attach report.pdf # Multiple recipients node scripts/smtp.js send --to "a@example.com,b@example.com" --cc "c@example.com" --subject "Update" --body "Team update"
test
Test SMTP connection by sending a test email to yourself.
node scripts/smtp.js [--account <name>] test
Dependencies
npm install
Security Notes
- Credentials are stored in
with~/.openclaw/.env
permissions (owner read/write only). Connection config is in600
in the skill directoryconfig.env - Gmail: regular password is rejected — generate an App Password at https://myaccount.google.com/apppasswords
- For 163.com: use authorization code (授权码), not account password
Troubleshooting
Connection timeout:
- Verify server is running and accessible
- Check host/port configuration
Authentication failed:
- Verify username (usually full email address)
- Check password is correct
- For 163.com: use authorization code, not account password
- For Gmail: regular password won't work — generate an App Password at https://myaccount.google.com/apppasswords
- For Yahoo Mail: regular password won't work — generate an App Password at https://login.yahoo.com/account/security
TLS/SSL errors:
- Match
/IMAP_TLS
setting to server requirementsSMTP_SECURE - For self-signed certs: set
orIMAP_REJECT_UNAUTHORIZED=falseSMTP_REJECT_UNAUTHORIZED=false