jmap-email
Enables JMAP email operations using Node.js and jmap-jam library. Use when working with JMAP email servers, FastMail, Cyrus IMAP, Stalwart Mail Server, or when user mentions email search, reading, sending, or mailbox management.
$ Instalar
git clone https://github.com/jacobrask/claude-skills /tmp/claude-skills && cp -r /tmp/claude-skills/skills/jmap-email ~/.claude/skills/claude-skills// tip: Run this command in your terminal to install the skill
name: jmap-email description: Enables JMAP email operations using Node.js and jmap-jam library. Use when working with JMAP email servers, FastMail, Cyrus IMAP, Stalwart Mail Server, or when user mentions email search, reading, sending, or mailbox management.
JMAP Email Access
Access JMAP email servers (FastMail, Cyrus IMAP, Stalwart) using pre-built scripts.
Prerequisites
Environment variables must be set before launching Claude Code:
JMAP_SESSION_URL- JMAP server session URLJMAP_BEARER_TOKEN- Authentication bearer tokenJMAP_ACCOUNT_ID- Account ID (optional, auto-detected)
Available Scripts
Choose the right script:
- Browse recent emails? → Use
list-emails.ts(supports --unread, --flagged, --mailbox, --from, --limit filters) - Search by sender? → Use
list-emails.ts --from "sender@example.com" - Search for multiple keywords? → Use
search-keywords.ts keyword1 keyword2 ... - Get full email content? → Use
get-email.tswith email ID - View folder structure? → Use
list-mailboxes.ts - Move emails by ID? → Use
move-by-ids.ts --mailbox <name> <id1> <id2> ... - Delete emails? → Use
delete-emails.ts <id1> <id2> ...
All scripts support --help for detailed usage.
Common Tasks
Browse unread emails
node scripts/list-emails.ts --unread
node scripts/list-emails.ts --unread --limit 50
Find emails from specific sender
node scripts/list-emails.ts --from "sender@example.com"
node scripts/list-emails.ts --from "sender@example.com" --unread
Search for receipts or specific content
node scripts/search-keywords.ts "invoice" "receipt" "order confirmation"
node scripts/search-keywords.ts --mailbox "Archive" --limit 10 "meeting" "agenda"
Note: Search shows previews only. For full email content, use get-email.ts with the email ID.
Get full email content
node scripts/get-email.ts <email-id>
Organize emails (classification workflow)
- Search for candidates:
search-keywords.ts "keyword1" "keyword2" - Review previews and identify relevant email IDs
- (Optional) View full content:
get-email.ts <email-id> - Move to target mailbox:
move-by-ids.ts --mailbox @MailboxName id1 id2 id3
Interactive email triage
Workflow for processing new emails with learning:
-
Fetch recent emails:
- Use
list-emails.ts --limit 20to get batch (optionally add--unreador--mailbox "Inbox") - Review subject, sender, and preview
- Use
-
Present classification options:
- Use AskUserQuestion with multiSelect for each email
- Options should be target mailboxes (Inbox, Archive, @Reference, etc.)
- Allow user to select destination for each email
-
Execute moves:
- Group emails by target mailbox
- Use
move-by-ids.ts --mailbox <name> <id1> <id2> ...for each group
-
Save routing patterns to memory:
- Note sender domains and subjects that map to specific mailboxes
- Record user's classification decisions (e.g., "newsletters from X → Archive")
- Reference these patterns in future triage sessions
- Suggest automatic routing rules based on observed patterns
Benefits:
- Process inbox in batches with interactive guidance
- Build up routing knowledge over time
- Suggest classifications based on past decisions
- Gradually automate common routing patterns
View mailbox structure
node scripts/list-mailboxes.ts
Output Format
Scripts output compact, human-readable results:
Found 5 email(s) (unread)
================================================================================
⭐ [UNREAD] Meeting tomorrow
From: John Doe <john@example.com>
Date: 1/15/2024, 10:30:45 AM
ID: StrgucNsyw-3
Preview: Hi Jane, let's meet at 2pm to discuss the project...
--------------------------------------------------------------------------------
Advanced Usage
For writing custom JMAP operations or understanding the API, see:
- Code Examples: examples.md
- API Reference: reference.md
- Development Guide: DEVELOPMENT.md
Repository
