pp-smartlead
Every SmartLead API feature, plus a local mirror that answers campaign-health, silent-lead, and cross-campaign... Trigger phrases: `check my smartlead campaigns`, `which leads went silent`, `is this domain already pitched`, `rank my sender accounts`, `use smartlead`, `run smartlead`.
What this skill does
<!-- GENERATED FILE — DO NOT EDIT.
This file is a verbatim mirror of library/sales-and-crm/smartlead/SKILL.md,
regenerated post-merge by tools/generate-skills/. Hand-edits here are
silently overwritten on the next regen. Edit the library/ source instead.
See the repository agent guide, section "Generated artifacts: registry.json, cli-skills/". -->
# SmartLead — Printing Press CLI
## Prerequisites: Install the CLI
This skill drives the `smartlead-pp-cli` binary. **You must verify the CLI is installed before invoking any command from this skill.** If it is missing, install it first:
1. Install via the Printing Press installer. It defaults binaries to `$HOME/.local/bin` on macOS/Linux and `%LOCALAPPDATA%\Programs\PrintingPress\bin` on Windows:
```bash
npx -y @mvanhorn/printing-press-library install smartlead --cli-only
```
2. Verify: `smartlead-pp-cli --version`
3. Ensure the reported install directory is on `$PATH` for the agent/runtime that will invoke this skill.
If the `npx` install fails (no Node, offline, etc.), fall back to a direct Go install (requires Go 1.26.3 or newer):
```bash
go install github.com/mvanhorn/printing-press-library/library/sales-and-crm/smartlead/cmd/smartlead-pp-cli@latest
```
If `--version` reports "command not found" after install, the runtime cannot see the binary directory on `$PATH`. Do not proceed with skill commands until verification succeeds.
## When to Use This CLI
Use this CLI when an agent or operator needs to audit cold-email outreach in SmartLead: checking which campaigns are healthy, building follow-up lists of silent leads, deduplicating leads across campaigns before launch, or ranking sender accounts by deliverability. It is the right tool when the question spans multiple campaigns or needs week-over-week history, because those answers come from the local mirror rather than a single API call.
## Unique Capabilities
These capabilities aren't available in any other tool for this API.
### Local state that compounds
- **`health`** — One-shot scorecard for every campaign — bounce rate, reply rate, silent-lead count, sender count, and a stale flag — without clicking through the dashboard.
_Reach for this first when an agent needs to know which campaigns are healthy before drilling into any one of them._
```bash
smartlead-pp-cli health --json
```
- **`silent`** — Finds leads that were emailed but have not replied within N days — the exact set to follow up with or retire.
_Use this to build a follow-up list instead of paging the whole lead set and diffing timestamps by hand._
```bash
smartlead-pp-cli silent --campaign 12345 --days 7 --json
```
- **`dupes`** — Scans the whole lead mirror for emails or domains that appear in two or more campaigns; --domain prints the full pitch ledger for one site.
_Run this before adding leads to a campaign to avoid double-contacting a prospect already in flight._
```bash
smartlead-pp-cli dupes --domain example.com --json
```
- **`drift`** — Computes week-over-week reply, open, and bounce deltas for a campaign by querying analytics one seven-day window at a time.
_Use this to catch a campaign decaying over time rather than judging it from a single point-in-time stat._
```bash
smartlead-pp-cli drift --campaign 12345 --weeks 4 --json
```
### Deliverability intelligence
- **`sender-health`** — Ranks every email sender account by a composite of inbox-warmup landing rate, SMTP/IMAP connection health, and sending utilization.
_Reach for this to find which sender accounts are dragging deliverability before they tank a campaign._
```bash
smartlead-pp-cli sender-health --json
```
- **`warmup-gate`** — Checks each sender account against warmup thresholds (--min-days, --min-inbox-rate); with --strict it exits non-zero when any account fails — a scriptable launch gate.
_Call this in a launch script to block attaching a sender account that is not warmed up yet._
```bash
smartlead-pp-cli warmup-gate --account 6789 --json
```
## Command Reference
**campaigns** — Manage campaigns
- `smartlead-pp-cli campaigns create` — Create a new campaign
- `smartlead-pp-cli campaigns delete` — Delete a campaign
- `smartlead-pp-cli campaigns get` — Get a campaign by ID
- `smartlead-pp-cli campaigns list` — Retrieves every email campaign for the authenticated SmartLead account.
**client** — Manage client
- `smartlead-pp-cli client create` — Create a whitelabel client
- `smartlead-pp-cli client list` — List all whitelabel clients
**email-accounts** — Manage email accounts
- `smartlead-pp-cli email-accounts create` — Add a new email sender account
- `smartlead-pp-cli email-accounts list` — List all email sender accounts
- `smartlead-pp-cli email-accounts reconnect-failed` — Trigger a reconnect of all disconnected email accounts
- `smartlead-pp-cli email-accounts update` — Update an email sender account
**leads** — Manage leads
- `smartlead-pp-cli leads add-domain-block-list` — Add domains to the account-wide block list
- `smartlead-pp-cli leads get-by-email` — Look up a lead by email address
- `smartlead-pp-cli leads list-categories` — List all lead categories for the account
- `smartlead-pp-cli leads update` — Update a lead's fields
### Finding the right command
When you know what you want to do but not which command does it, ask the CLI directly:
```bash
smartlead-pp-cli which "<capability in your own words>"
```
`which` resolves a natural-language capability query to the best matching command from this CLI's curated feature index. Exit code `0` means at least one match; exit code `2` means no confident match — fall back to `--help` or use a narrower query.
## Recipes
### Morning campaign triage
```bash
smartlead-pp-cli sync && smartlead-pp-cli health --json
```
Refresh the mirror, then get the all-campaigns health scorecard in one structured payload.
### Pre-launch dedupe check
```bash
smartlead-pp-cli dupes --domain prospect-site.com --json
```
See every campaign, category, and last-contact date for a domain before pitching it again.
### Build a follow-up list
```bash
smartlead-pp-cli silent --campaign 12345 --days 10 --json
```
Pull leads emailed but silent for 10+ days to feed into a follow-up sequence.
### Trim a verbose campaign payload
```bash
smartlead-pp-cli campaigns list --agent --select id,name,status
```
SmartLead campaign objects are large; --agent with --select narrows the response to just the fields an agent needs.
### Gate a launch on sender warmup
```bash
smartlead-pp-cli warmup-gate --account 6789 --json
```
Returns a typed exit code so a launch script can block on a sender that is not warmed up.
## Auth Setup
SmartLead authenticates with an API key passed as the api_key query parameter. Set SMARTLEAD_API_KEY in your environment (find the key under Settings -> API in the SmartLead app). No OAuth, no login flow.
Run `smartlead-pp-cli doctor` to verify setup.
## Agent Mode
Add `--agent` to any command. Expands to: `--json --compact --no-input --no-color --yes`.
- **Pipeable** — JSON on stdout, errors on stderr
- **Filterable** — `--select` keeps a subset of fields. Dotted paths descend into nested structures; arrays traverse element-wise. Critical for keeping context small on verbose APIs:
```bash
smartlead-pp-cli campaigns list --agent --select id,name,status
```
- **Previewable** — `--dry-run` shows the request without sending
- **Offline-friendly** — sync/search commands can use the local SQLite store when available
- **Non-interactive** — never prompts, every input is a flag
- **Explicit retries** — use `--idempotent` only when an already-existing create should count as success, and `--ignore-missing` only when a missing delete target should count as success
### Response envelope
Commands that read from the local store or the API wrap output in a provenance envelope:
```json
{
"meta": {"source": "live" | "local", "synced_at": "...", "reason": ".Related in Ads & Marketing
ads
IncludedMulti-platform paid advertising audit and optimization skill. Analyzes Google, Meta, YouTube, LinkedIn, TikTok, Microsoft, and Apple Ads. 250+ checks with scoring, parallel agents, industry templates, and AI creative generation.
banana
IncludedAI image generation Creative Director powered by Google Gemini Nano Banana models. Use this skill for ANY request involving image creation, editing, visual asset production, or creative direction. Triggers on: generate an image, create a photo, edit this picture, design a logo, make a banner, visual for my anything, and all /banana commands. Handles text-to-image, image editing, multi-turn creative sessions, batch workflows, and brand presets.
rpg-migration-analyzer
IncludedAnalyzes legacy RPG (Report Program Generator) programs from AS/400 and IBM i systems for migration to modern Java applications. Extracts business logic from RPG III/IV/ILE source code, identifies data structures (D-specs), file operations (F-specs), program dependencies (CALLB/CALLP), and converts RPG constructs to Java equivalents. Generates migration reports, complexity estimates, and Java implementation strategies with POJO classes, JPA entities, and service methods. Use when modernizing AS/400 or IBM i legacy systems, analyzing RPG source files (.rpg, .rpgle, .RPGLE), converting RPG to Java, mapping data specifications to Java classes, planning legacy system migration, or when user mentions RPG analysis, Report Program Generator, RPG III/IV/ILE, AS/400 modernization, IBM i migration, packed decimal conversion, or mainframe application rewrite.
brand-library-architect
IncludedBuild a complete brand library for a product — visual asset render pipeline, brand documentation set (BRAND, COPY, MANIFESTO, BIOS, FAQ, GLOSSARY, TONE, PRICING), open-source convention files (README, CONTRIBUTING, SECURITY, CODE_OF_CONDUCT), and a self-contained press kit. This skill should be used when the user asks to "build a brand library / brand kit / press kit / brand assets" for a product, "set up a brand library workflow," "create a positioning manifesto plus visual identity," or any combination of brand documentation + visual asset pipeline. Apply phase-by-phase or run end-to-end. Templates are product-agnostic and use {{TOKEN}} placeholders the skill prompts the user to fill.
writing-tech-post
IncludedAuthors engineering blog posts end-to-end: launch deep-dives, incident postmortems, architecture migrations, performance case studies, tutorials, AI/agent system writeups, security disclosures, and research-to-product translations. Picks the correct archetype, plans the abstraction ladder, enforces an evidence cadence (diagrams, benchmarks, profiles, traces, code, ablations), tunes voice against publisher house styles (Datadog, Vercel, GitHub, AWS, Meta, Cloudflare, Jane Street), and runs a pre-publish gate for narrative momentum and disclosure ethics. Use when drafting a new engineering post, restructuring a draft that feels flat, deciding which evidence form belongs where, validating that depth and product context are balanced, or preparing a postmortem, migration, or performance narrative for external publication. Do not use for API reference documentation, README authoring, marketing copy, release notes, generic SEO content, ghost-written executive thought leadership, or non-engineering long-form essays.
blog-google
IncludedGoogle API integration for blog performance: PageSpeed Insights, CrUX Core Web Vitals with 25-week history, Search Console performance, URL Inspection, Indexing API, GA4 organic traffic, NLP entity analysis for E-E-A-T, YouTube video search for embedding, and Google Ads Keyword Planner. Progressive feature availability based on credential tier (API key, OAuth/service account, GA4, Ads). Shares config with claude-seo at ~/.config/claude-seo/google-api.json. Use when user says "google data", "page speed", "core web vitals", "search console", "indexation", "GA4", "keyword research", "nlp entities", "blog performance", "youtube search", "google api setup".