| name | zele |
| description | zele is a multi-account email and calendar CLI for Gmail, IMAP/SMTP (Fastmail, Outlook, any provider), and Google Calendar. It reads, searches, sends, replies, forwards, archives, stars, and trashes emails, manages drafts, labels, attachments, and Gmail filters, and creates, updates, and deletes calendar events with RSVP and free/busy support. Output is YAML so commands can be piped through yq and xargs. ALWAYS load this skill when the user asks to check email, read/send messages, reply or forward, archive or trash threads, manage drafts or labels, download attachments, schedule meetings, check their calendar, RSVP to events, or when they run any `zele` command. Load it before writing any code or shell commands that touch zele so you know the correct subcommand structure, the Google vs IMAP feature matrix, the headless login flow, and the agent-specific rules.
|
zele
Every time you use zele, you MUST fetch the latest README:
curl -s https://raw.githubusercontent.com/remorses/zele/main/README.md
Then run the CLI help once โ it already includes every subcommand, option, and flag:
zele --help
The README and zele --help output are the source of truth for commands, options, flags, the Google vs IMAP feature matrix, search operators, and the headless login flow.
Rules
- Never use the TUI. Running
zele with no subcommand launches a human-facing TUI. Agents must use the CLI subcommands (zele mail list, zele cal events, etc.) which output structured YAML.
- Always run
zele whoami first when the user asks to operate on a specific account. Pick the exact email from the output and pass it with --account. Never guess account emails.
- Never truncate
--help or README output with head, tail, sed, awk, or less. Critical rules are spread throughout. Read them in full.
- Parse YAML output with
yq, not regex. Pipe IDs through xargs for bulk actions. Always use --limit 100 (or higher) so you don't miss threads:
zele mail list --filter "is:unread" --limit 100 | yq '.[].id' | xargs zele mail read
zele mail list --filter "is:unread" --limit 100 | yq '.[].id' | xargs zele mail archive
- Google-only features (labels, Gmail filters,
zele cal *, full profile) fail on IMAP accounts with a clear error. Check zele whoami output for account type before using them.
- Headless Google login requires a tmux wrapper because
zele login is interactive. See the README "Remote / headless login" section for the exact pattern.