pp-allrecipes
Allrecipes — Printing Press CLI
Prerequisites: Install the CLI
This skill drives the allrecipes-pp-cli binary. You must verify the CLI is installed before invoking any command from this skill. If it is missing, install it first:
- Install via the Printing Press installer:
npx -y @mvanhorn/printing-press install allrecipes --cli-only - Verify:
allrecipes-pp-cli --version - Ensure
$GOPATH/bin(or$HOME/go/bin) is on$PATH.
If the npx install fails (no Node, offline, etc.), fall back to a direct Go install (requires Go 1.23+):
go install github.com/mvanhorn/printing-press-library/library/food-and-dining/allrecipes/cmd/allrecipes-pp-cli@latest
If --version reports "command not found" after install, the install step did not put the binary on $PATH. Do not proceed with skill commands until verification succeeds.
When to Use This CLI
Reach for this CLI when an agent or user needs Allrecipes data as data, not as a webpage: searching for proven recipes, fetching ingredient lists in structured form, building grocery lists across multiple recipes, scaling for different serving counts, or filtering by what's in the pantry. The local SQLite cache makes iterative meal-planning workflows fast — every recipe fetched is queryable forever via pantry, with-ingredient, top-rated, and dietary. Skip this CLI when the user wants a multi-site comparison (different tool) or when they need authenticated features like saved recipes or meal plans (intentionally not supported).
When Not to Use This CLI
Do not activate this CLI for requests that require creating, updating, deleting, publishing, commenting, upvoting, inviting, ordering, sending messages, booking, purchasing, or changing remote state. This printed CLI exposes read-only commands for inspection, export, sync, and analysis.
Unique Capabilities
These capabilities aren't available in any other tool for this API.
Local state that compounds
-
pantry— Score Allrecipes recipes against your pantry — see which ones you can actually cook tonight without a grocery run.When the user says 'what can I make with what I've got', this is the only command that knows the answer.
allrecipes-pp-cli pantry --pantry-file ~/pantry.txt --query brownies --agent -
with-ingredient— Find every cached recipe that uses a given ingredient — a SQL view across your local corpus.Use this when the user starts from an ingredient they want to use up, not a dish name.
allrecipes-pp-cli with-ingredient buttermilk --top 10 --agent -
dietary— Filter cached recipes by gluten-free / vegan / low-carb using JSON-LD keywords plus ingredient-name patterns.Use this when dietary restrictions are non-negotiable and the user wants more than what the site's diet category page surfaces.
allrecipes-pp-cli dietary --type gluten-free --top 20 --agent
Ranking that beats the website
-
top-rated— Rank recipes by Bayesian-smoothed rating — proven popular wins over 1-review 5-star noise.Pick this over raw search when the agent wants proven recipes, not freshly-uploaded 5-star outliers.
allrecipes-pp-cli top-rated brownies --smooth-c 200 --limit 10 --agent -
quick— Top-rated recipes that fit a strict time cap — Allrecipes' UI cannot enforce one, but the local cache can.Use this when the user's constraint is time, not dish — 'what can I make in 25 minutes that's actually good'.
allrecipes-pp-cli quick --max-minutes 30 --query chicken --agent
Agent-native plumbing
-
cookbook— Compile a top-rated category into a single markdown cookbook with TOC, ingredients, and instructions.When the user asks for a curated bundle (gifts, meal-plan packs), this builds it in one command.
allrecipes-pp-cli cookbook --category italian --top 20 --output italian-cookbook.md -
grocery-list— Aggregate ingredients from many recipes into a deduped, agent-readable shopping list.Use this at the end of a meal plan — one call replaces five scrolls through ingredient lists.
allrecipes-pp-cli grocery-list https://www.allrecipes.com/recipe/9599/quick-and-easy-brownies/ https://www.allrecipes.com/recipe/16354/easy-meatloaf/ --agent
Reachability mitigation
-
doctor— Health check that names the Cloudflare 'Just a moment...' interstitial by inspecting the response body, then advises the browser-chrome transport.When the CLI breaks because of bot detection, the agent gets a specific, actionable error rather than a generic timeout.
allrecipes-pp-cli doctor
HTTP Transport
This CLI uses Chrome-compatible HTTP transport over HTTP/3 for browser-facing endpoints. It does not require a resident browser process for normal API calls.
Command Reference
recipes — Public Allrecipes recipe pages with Schema.org Recipe JSON-LD markup
allrecipes-pp-cli recipes get— Fetch a recipe by ID + slug; returns parsed JSON-LD Recipe. Requires Cloudflare clearance cookie via `auth login...allrecipes-pp-cli recipes search— Search Allrecipes for recipes matching a query (no Cloudflare clearance required).
Hand-written commands
allrecipes-pp-cli recipe <url-or-id>— Fetch and render a single recipe by URL or IDallrecipes-pp-cli search <query>— Search Allrecipes for recipes (live + cache)allrecipes-pp-cli top-rated <query>— Search and rank by Bayesian-smoothed rating (prior 4.0, default C=200)allrecipes-pp-cli quick— Recipes from cache that fit a strict time cap and are top-ratedallrecipes-pp-cli pantry— Score cached recipes by overlap with a pantry fileallrecipes-pp-cli with-ingredient <ingredient>— Reverse index: cached recipes that use a given ingredientallrecipes-pp-cli dietary— Filter cached recipes by gluten-free / vegan / low-carb (strict ingredient blocklist)allrecipes-pp-cli cookbook— Compile a top-rated category or cuisine into a markdown cookbookallrecipes-pp-cli grocery-list <urls...>— Aggregate ingredients across many recipes into a deduped shopping list (subtract --pantry-file if given)allrecipes-pp-cli scale <url>— Rescale a recipe to a target serving countallrecipes-pp-cli nutrition <url>— Show nutrition for a recipe (per serving and total)allrecipes-pp-cli ingredients <url>— Show parsed ingredients for a recipeallrecipes-pp-cli instructions <url>— Show numbered instructions for a recipeallrecipes-pp-cli reviews <url>— Show review summary for a recipeallrecipes-pp-cli category <slug>— Browse recipes in a category (e.g. dessert, weeknight)allrecipes-pp-cli cuisine <slug>— Browse recipes by cuisineallrecipes-pp-cli ingredient <name>— Browse recipes featuring a primary ingredientallrecipes-pp-cli occasion <slug>— Browse recipes by occasion (holiday, weeknight, party)allrecipes-pp-cli article <url>— Extract the body of an Allrecipes article pageallrecipes-pp-cli gallery <url>— Extract recipe links from an Allrecipes round-up galleryallrecipes-pp-cli cook <slug>— Show a cook profile and their recipesallrecipes-pp-cli export <url>— Export a recipe as markdownallrecipes-pp-cli sync— Refresh cached recipes that are staleallrecipes-pp-cli cache— Inspect, list, or clear the local recipe cacheallrecipes-pp-cli doctor— Diagnose connectivity, Cloudflare clearance state, and cache health
Freshness Contract
This printed CLI owns bounded freshness only for registered store-backed read command paths. In --data-source auto mode, those paths check sync_state and may run a bounded refresh before reading local data. --data-source local never refreshes. --data-source live reads the API and does not mutate the local store. Set ALLRECIPES_NO_AUTO_REFRESH=1 to skip the freshness hook without changing source selection.
When JSON output uses the generated provenance envelope, freshness metadata appears at meta.freshness. Treat it as current-cache freshness for the covered command path, not a guarantee of complete historical backfill or API-specific enrichment.
Finding the right command
When you know what you want to do but not which command does it, ask the CLI directly:
allrecipes-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
Top 5 brownies, narrowed to ranking fields only
allrecipes-pp-cli top-rated brownies --limit 5 --agent --select rank,title,url,rating,reviewCount,madeItCount
Bayesian smoothing kills 1-review 5-star outliers; --select trims the payload to fields agents actually use.
Plan three weeknight dinners and one grocery list
allrecipes-pp-cli quick --max-minutes 30 --query chicken --limit 3 --agent | xargs allrecipes-pp-cli grocery-list --pantry-file ~/pantry.txt --agent
Compose two commands: quick weeknight selection feeds straight into pantry-aware grocery aggregation.
Compile a personal Italian cookbook
allrecipes-pp-cli cookbook --category italian --top 20 --output ~/italian-cookbook.md
Pulls the top-20 by Bayesian rating and writes a markdown cookbook with TOC.
Cook with what's in the pantry
allrecipes-pp-cli pantry --pantry-file ~/pantry.txt --max-missing 2 --agent --select title,url,have,missing
Local index ranks cached recipes by ingredient overlap; --max-missing 2 keeps recipes that need at most two extra ingredients.
Strict gluten-free with field narrowing
allrecipes-pp-cli dietary --type gluten-free --top 20 --agent --select title,url,rating,recipeIngredient
Strict ingredient blocklist + JSON-LD tag filter; --select pulls only the title, url, rating, and ingredients for agent verification.
Auth Setup
Browse and search work without any auth. Recipe detail pages need a Cloudflare clearance cookie — run allrecipes-pp-cli auth login --chrome once to capture one from your browser. This is bot-protection clearance, not an Allrecipes account login: no username, no password, no token tied to a user. The CLI does not support saved-recipes / meal-plan / profile features that require an actual Allrecipes account.
Run allrecipes-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 —
--selectkeeps a subset of fields. Dotted paths descend into nested structures; arrays traverse element-wise. Critical for keeping context small on verbose APIs:allrecipes-pp-cli recipes get mock-value mock-value --agent --select id,name,status -
Previewable —
--dry-runshows 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
-
Read-only — do not use this CLI for create, update, delete, publish, comment, upvote, invite, order, send, or other mutating requests
Response envelope
Commands that read from the local store or the API wrap output in a provenance envelope:
{
"meta": {"source": "live" | "local", "synced_at": "...", "reason": "..."},
"results": <data>
}
Parse .results for data and .meta.source to know whether it's live or local. A human-readable N results (live) summary is printed to stderr only when stdout is a terminal — piped/agent consumers get pure JSON on stdout.
Agent Feedback
When you (or the agent) notice something off about this CLI, record it:
allrecipes-pp-cli feedback "the --since flag is inclusive but docs say exclusive"
allrecipes-pp-cli feedback --stdin < notes.txt
allrecipes-pp-cli feedback list --json --limit 10
Entries are stored locally at ~/.allrecipes-pp-cli/feedback.jsonl. They are never POSTed unless ALLRECIPES_FEEDBACK_ENDPOINT is set AND either --send is passed or ALLRECIPES_FEEDBACK_AUTO_SEND=true. Default behavior is local-only.
Write what surprised you, not a bug report. Short, specific, one line: that is the part that compounds.
Output Delivery
Every command accepts --deliver <sink>. The output goes to the named sink in addition to (or instead of) stdout, so agents can route command results without hand-piping. Three sinks are supported:
| Sink | Effect |
|---|---|
stdout |
Default; write to stdout only |
file:<path> |
Atomically write output to <path> (tmp + rename) |
webhook:<url> |
POST the output body to the URL (application/json or application/x-ndjson when --compact) |
Unknown schemes are refused with a structured error naming the supported set. Webhook failures return non-zero and log the URL + HTTP status on stderr.
Named Profiles
A profile is a saved set of flag values, reused across invocations. Use it when a scheduled agent calls the same command every run with the same configuration - HeyGen's "Beacon" pattern.
allrecipes-pp-cli profile save briefing --json
allrecipes-pp-cli --profile briefing recipes get mock-value mock-value
allrecipes-pp-cli profile list --json
allrecipes-pp-cli profile show briefing
allrecipes-pp-cli profile delete briefing --yes
Explicit flags always win over profile values; profile values win over defaults. agent-context lists all available profiles under available_profiles so introspecting agents discover them at runtime.
Exit Codes
| Code | Meaning |
|---|---|
| 0 | Success |
| 2 | Usage error (wrong arguments) |
| 3 | Resource not found |
| 4 | Authentication required |
| 5 | API error (upstream issue) |
| 7 | Rate limited (wait and retry) |
| 10 | Config error |
Argument Parsing
Parse $ARGUMENTS:
- Empty,
help, or--help→ showallrecipes-pp-cli --helpoutput - Starts with
install→ ends withmcp→ MCP installation; otherwise → see Prerequisites above - Anything else → Direct Use (execute as CLI command with
--agent)
MCP Server Installation
- Install the MCP server:
go install github.com/mvanhorn/printing-press-library/library/food-and-dining/allrecipes/cmd/allrecipes-pp-mcp@latest - Register with Claude Code:
claude mcp add allrecipes-pp-mcp -- allrecipes-pp-mcp - Verify:
claude mcp list
Direct Use
- Check if installed:
which allrecipes-pp-cliIf not found, offer to install (see Prerequisites at the top of this skill). - Match the user query to the best command from the Unique Capabilities and Command Reference above.
- Execute with the
--agentflag:allrecipes-pp-cli <command> [subcommand] [args] --agent - If ambiguous, drill into subcommand help:
allrecipes-pp-cli <command> --help.
More from mvanhorn/printing-press-library
pp-flight-goat
Search Google Flights, scan Kayak long-haul routes, and join FlightAware AeroAPI reliability, alerts, and tracking from one CLI.
159pp-espn
Use this skill whenever the user asks about live sports scores, standings, team stats, game summaries (with box score, leaders, scoring plays, odds, and win probability), NFL / NBA / MLB / NHL / NCAA / MLS / EPL / WNBA games, team schedules, polls, or rankings. ESPN sports CLI with live scores across 10 leagues, offline search, head-to-head comparisons, and rich per-game summary payloads. No API key required. Triggers on natural phrasings like 'what's the score of the Lakers game', 'Patriots schedule this week', 'NFL standings', 'box score for tonight's Mavs game', 'Chiefs vs Eagles head to head', 'who's on top of the AP poll'.
142pp-recipe-goat
Printing Press CLI for Recipe Goat. Recipe GOAT — find the best version of any recipe across 37 trusted sites, with offline cookbook, pantry match,...
121pp-movie-goat
The movie CLI that combines TMDb's discovery engine with OMDb's multi-source ratings — and ships a SQLite watchlist that flags what's streaming on your services right now. Trigger phrases: `what should I watch tonight`, `where can I stream <title>`, `rate <title>`, `compare <title> and <title>`, `what's <person>'s filmography`, `plan a <franchise> marathon`, `use movie-goat`, `run movie-goat`.
119pp-company-goat
Look up startups across SEC Form D, GitHub, Hacker News, Companies House, YC, and Wikidata in one command — including the SEC fundraising data hidden behind paid Crunchbase tiers. Trigger phrases: `look up this startup`, `research <company>`, `what does <company> do`, `form D for <company>`, `is <company> still active`, `compare <a> and <b>`, `use company-goat`, `run company-goat-pp-cli`.
63pp-hackernews
Hacker News from your terminal — with a local SQLite store, snapshot history, and agent-native output no other HN tool has. Trigger phrases: `check hacker news`, `search hn`, `what is hn saying about`, `diff the hn front page`, `pulse on hn`, `look up hn user`, `hn who is hiring`, `hn top stories`, `use hackernews`, `run hackernews`.
54