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 # NEVER pipe to head/tail, read the full output
Then run the CLI help once — it already includes every subcommand, option, and flag:
zele --help # NEVER pipe to head/tail, read the full output
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
zelewith 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 whoamifirst 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
--helpor README output withhead,tail,sed,awk, orless. Critical rules are spread throughout. Read them in full. - Parse YAML output with
yq, not regex. Pipe IDs throughxargsfor bulk actions. Always use--limit 100(or higher) so you don't miss threads:# read all unread emails zele mail list --filter "is:unread" --limit 100 | yq '.[].id' | xargs zele mail read # bulk archive 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. Checkzele whoamioutput for account type before using them. - Headless Google login requires a tmux wrapper because
zele loginis interactive. See the README "Remote / headless login" section for the exact pattern. - Waiting for emails with
zele mail watch. It polls for new emails matching a filter and exits as soon as one arrives. Use this to wait for replies, verification codes, or any expected email:
If the matched email wasn't the expected one, call# wait for a reply from alice (no timeout, blocks until match) zele mail watch --filter "is:unread from:alice@example.com" # wait for a verification code with a 5-minute timeout zele mail watch --filter "is:unread subject:verification" --timeout 300 # send an email then wait for the reply zele mail send --to bob@example.com --subject "Question" --body "Hey, can you check this?" zele mail watch --filter "is:unread from:bob@example.com subject:Re:Question" --timeout 600zele mail watchagain with a more specific filter. Exit code 0 means a match was found, exit code 1 means timeout.