Resend CLI Skill
Use this skill when the task is specifically about operating Resend from an AI agent, terminal session, or CI job via the official resend CLI: installing/aut...
Description
name: resend-cli
description: "Use this skill when the task is specifically about operating Resend from an AI agent, terminal session, or CI job via the official resend CLI: installing/authenticating the CLI, sending/listing/updating/cancelling emails, batch sends, domains and DNS, webhooks and local listeners, inbound receiving, contacts, topics, segments, broadcasts, templates, API keys, profiles, or debugging Resend CLI/API failures. Trigger on mentions of Resend CLI, resend, resend doctor, resend emails send, resend domains, resend webhooks listen, resend emails receiving, or agent-friendly terminal automation."
compatibility: "Designed for skills-compatible coding agents. Live operations require the official resend CLI plus a RESEND_API_KEY or stored profile. The bundled helper uses Python 3.10+ standard library only."
metadata:
author: OpenAI
version: "3.0.0"
cli-version: "1.4.1"
source: "https://github.com/resend/resend-cli"
last-reviewed: "2026-03-14"
Resend CLI
This skill is for agents that should operate Resend through the official CLI first, not by dropping straight to raw REST.
The goal is not just “know the commands”. The goal is to make an agent:
- choose the right Resend primitive,
- choose the right CLI command,
- run it in a deterministic non-interactive way,
- detect the important CLI coverage gaps before it gets stuck, and
- fall back to MCP/API only when the CLI genuinely does not cover the job.
Start here
Load only the files that match the task:
references/agent-operating-model.md— the default decision process for live Resend workreferences/install-auth-and-profiles.md— install methods, auth priority, profiles, config pathsreferences/subprocess-contract.md— how agents should invokeresendsafely and parse outputreferences/command-selection.md— fast routing from user intent to the right command(s)references/sending-scheduling-and-batch.md— transactional sends, schedules, tags, attachments, batch limitsreferences/domains-dns-and-deliverability.md— domain creation, verification, receiving, TLS, tracking, 403/domain mismatchreferences/webhooks-and-listeners.md— webhook creation, update, signature handling, temporary local listenersreferences/inbound-receiving-and-threading.md— inbound list/get/attachments/forward/listen flowsreferences/contacts-topics-segments-and-broadcasts.md— subscription modelling, targeting, campaignsreferences/templates-and-coverage-gaps.md— template lifecycle and the important current CLI gapsreferences/diagnostics-and-fallbacks.md— debug order, CLI quirks, when to fall back to MCP/APIreferences/recipes.md— short end-to-end playbooksreferences/sources.md— first-party source manifest and refresh notes
Machine-readable assets:
assets/command-catalog.json— command index with detail levels (source_inspected,readme_confirmed,tree_confirmed)assets/task-router.json— route common tasks to command sequencesassets/error-map.json— fast-fail diagnosis hintsassets/coverage-gaps.json— current CLI limitations and ambiguities that matter to agentsassets/subprocess-contract.json— deterministic invocation defaultsassets/scaffold-index.json— reusable command/file scaffoldsassets/source-manifest.json— authoritative URLs used to build this skill
Bundled helper:
scripts/resend_cli.py— agent wrapper for probing, routing, scaffolding, batch linting, diagnosis, and safe subprocess execution
Core operating rules
1) Prefer the official CLI for live Resend work
Default order of preference:
- Official Resend CLI for live terminal/CI/agent operations
- Official Resend MCP server if the environment already exposes it and the CLI is unavailable
- Official SDK when editing app code inside an existing integration
- Raw REST only for stack-neutral examples, protocol debugging, or feature gaps
Do not choose raw REST just because it is familiar.
2) For agents, stay non-interactive by default
For bounded commands:
- pass all required flags explicitly
- use global
--json -q - prefer
RESEND_API_KEYor a stored profile over typing secrets interactively - set
RESEND_NO_UPDATE_NOTIFIER=1for deterministic output - capture both stdout and stderr defensively
3) Run doctor early when the environment is unknown
When you do not know whether the CLI is installed, authenticated, or pointed at the right account:
resend --json -q doctor
This is usually the fastest first read on:
- CLI availability/version
- whether an API key is being resolved
- whether verified domains exist
- whether the machine looks like an AI-agent environment
4) Choose the primitive before the command
- One logical transactional email →
emails send - Up to 100 distinct transactional emails in one request →
emails batch - Scheduled transactional email mutation →
emails update/emails cancel - Campaign to a segment →
broadcasts create/broadcasts send - Reusable hosted content →
templates * - Sender or receiving setup →
domains * - Inbound processing →
emails receiving *+webhooks * - Scoped credentials →
api-keys * - Recipient data and preferences →
contacts,contact-properties,topics,segments - Local dev event loop →
webhooks listenoremails receiving listen
5) Know the current CLI gaps
This version of the skill treats these as especially important:
- Template send gap: the CLI manages templates, but the current
emails sendcommand surface does not expose a direct--template-id/template-vars flow. - Domain capability update gap:
domains updateexposes TLS/open/click tracking, but not an explicit sending/receiving capability toggle, while inbound help text references such a toggle. - Stream commands are special:
webhooks listenandemails receiving listenare long-running and should be treated as NDJSON/event streams in agent mode. - JSON error channel discrepancy: the README promises machine JSON on stdout only, but the current source writes JSON errors with
console.error, so wrappers must parse stderr too.
6) Keep IDs and file paths
Most multi-step flows become much easier if the agent persists:
- domain IDs
- email IDs
- webhook IDs
- topic IDs
- segment IDs
- template IDs/aliases
- API key IDs
- the file paths it generated for HTML or batch JSON
The mutation ladder
For state-changing live operations:
- classify the task
- confirm the command sequence
- make any needed file assets (
.html, batch JSON) - run with
--json -q - verify with
get,list, or a follow-up check - persist returned IDs and next-step context
- only then continue to the next mutation
Bundled helper script
scripts/resend_cli.py is intentionally agent-oriented.
Commands:
probe— find the CLI, report install hints, and show environment basicscatalog— list known commands from the bundled catalogueinfo— inspect one command and its notes/gapsrecommend— route a free-text task to the best CLI sequencescaffold— print or materialise sample commands/fileslint-batch— statically validate anemails batchJSON filedoctor— explain likely causes of common CLI/API failuresrun— execute the official CLI with deterministic defaults and tolerant JSON parsing
Examples:
python3 scripts/resend_cli.py probe
python3 scripts/resend_cli.py catalog --resource emails
python3 scripts/resend_cli.py info "emails send"
python3 scripts/resend_cli.py recommend "send 70 different shipment notifications"
python3 scripts/resend_cli.py scaffold batch-send --write-dir ./tmp
python3 scripts/resend_cli.py lint-batch ./tmp/batch-emails.json
python3 scripts/resend_cli.py doctor --command "emails send" --status 403 --message "1010 forbidden"
python3 scripts/resend_cli.py run -- emails list --limit 5
Response shape this skill should produce
A strong answer usually includes:
- the exact Resend primitive,
- the exact CLI command or command sequence,
- any file scaffolding the user needs,
- the operational caveats that matter here,
- the verification step,
- the fallback path if the CLI does not currently cover the flow.
Example prompts this skill should handle
- “Use the Resend CLI to send a scheduled password reset email”
- “Should I use
emails send,emails batch, orbroadcasts create?” - “Create a sending + receiving domain in
eu-west-1” - “Set up local webhook listening with ngrok”
- “Why is my batch file failing?”
- “How do I manage multiple Resend accounts from one agent?”
- “Can the CLI send a hosted template directly?”
- “How should my agent parse
resendoutput safely?”
Reviews (0)
No reviews yet. Be the first to review!
Comments (0)
No comments yet. Be the first to share your thoughts!