pp-ankiweb
The only terminal-native way to search, rank Trigger phrases: `ankiweb shared decks`, `search anki decks`, `best anki deck for`, `download anki deck`, `my synced anki decks`, `use ankiweb`, `run ankiweb`.
What this skill does
<!-- GENERATED FILE — DO NOT EDIT.
This file is a verbatim mirror of library/education/ankiweb/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/". -->
# AnkiWeb — Printing Press CLI
## Prerequisites: Install the CLI
This skill drives the `ankiweb-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 ankiweb --cli-only
```
2. Verify: `ankiweb-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/education/ankiweb/cmd/ankiweb-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
Reach for AnkiWeb CLI when you want to discover, evaluate, or track community shared decks from the terminal or an agent, list your cloud-synced decks, search the cards already in your collection, or add new notes. It is the right tool for ranking decks by quality, filtering by audio coverage, comparing candidates, watching for new decks, searching your own cards, and adding cards — things the AnkiWeb website does slowly or an agent cannot otherwise reach. For editing or deleting existing cards, reviewing/studying, or local desktop automation, use an AnkiConnect-based tool instead.
## When Not to Use This CLI
Do not activate this CLI for requests that edit or delete existing cards, review/study cards, create decks, or perform local desktop automation — use an AnkiConnect-based tool for those. The only write this CLI performs is adding new notes via `notes add` (guarded by `--dry-run` and confirmation); everything else is read-only inspection, search, sync, and analysis.
## Unique Capabilities
These capabilities aren't available in any other tool for this API.
### Catalog intelligence the website can't do
- **`shared rank`** — Rank shared decks by approval rate (upvotes vs downvotes) with a minimum-vote floor, instead of the raw vote counts the website shows.
_Pick the highest-quality deck for a topic in one command instead of eyeballing vote counts deck by deck._
```bash
ankiweb-pp-cli shared rank spanish --min-votes 20 --agent
```
- **`shared search`** — Filter shared decks by whether they include audio or images, critical for language learners.
_Surface only media-rich decks when audio matters (language study) without opening each deck._
```bash
ankiweb-pp-cli shared search japanese --has-audio --agent
```
- **`compare`** — Compare multiple shared decks in one table: approval rate, note count, audio/image coverage, and freshness.
_Decide between near-duplicate decks at a glance instead of flipping between tabs._
```bash
ankiweb-pp-cli compare 241428882 815543631 --agent
```
- **`shared fresh`** — Rank or filter shared decks by last-modified date to surface actively maintained decks.
_Avoid stale abandoned decks by finding the ones updated recently._
```bash
ankiweb-pp-cli shared fresh anatomy --since 2024-01-01 --agent
```
### Local state that compounds
- **`watch`** — Show shared decks that are new or changed for a search term since your last sync.
_Re-run a weekly topic search and see only what's new instead of re-scanning the whole list._
```bash
ankiweb-pp-cli watch spanish --since-last-sync --agent
```
- **`drift`** — Track download-count changes on the decks you've published, between syncs.
_See whether your published decks are gaining traction over time without manual note-taking._
```bash
ankiweb-pp-cli drift --agent
```
- **`brief`** — One digest for a topic: top decks by approval rate, audio coverage, the freshest deck, and how many are new since last sync.
_Get a complete read on a topic's deck landscape in one call instead of running four commands._
```bash
ankiweb-pp-cli brief spanish --agent
```
## Discovery Signals
This CLI was generated with browser-observed traffic context.
- Capture coverage: 5 API entries from 6 total network entries
- Protocols: protobuf (95% confidence), sveltekit_spa (90% confidence)
- Auth signals: cookie — cookies: has_auth
- Generation hints: protobuf_responses_require_handwritten_decoders, cookie_auth_validated, download_requires_signed_token
- Candidate command ideas: search — GET /svc/shared/list-decks?search= returns repeated deck protobuf {id,title,upvotes,downvotes,modified,notes,audio,images}; info — GET /svc/shared/item-info?sharedId= returns full deck detail + reviews protobuf; download — GET /svc/shared/download-deck/{id}?t= requires client-minted signed token (op=sdd); token generation unresolved; list — POST /svc/decks/deck-list-info returns user's synced decks; cookie-gated
- Caveats: : All API responses are protobuf, not JSON; generated JSON decoding will not work without hand-written wire-format readers.; : Shared-deck download needs a signed ?t= token minted by AnkiWeb client JS; not reproducible from captured traffic alone.
## Command Reference
**decks** — Your cloud-synced decks and study stats (requires AnkiWeb login)
- `ankiweb-pp-cli decks` — List your synced decks with card counts and study stats (protobuf response; 200 with session cookie, 403 without)
**shared** — Browse, search, and download public shared decks (no login required)
- `ankiweb-pp-cli shared download` — Download a shared deck .apkg. NOTE: requires a signed ?
- `ankiweb-pp-cli shared info` — Full detail + reviews for one shared deck (protobuf response)
- `ankiweb-pp-cli shared search` — Search the shared-deck catalog by keyword (protobuf response)
### Finding the right command
When you know what you want to do but not which command does it, ask the CLI directly:
```bash
ankiweb-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
### Find the best audio-rich Spanish deck
```bash
ankiweb-pp-cli shared rank spanish --has-audio --min-votes 20 --agent --select decks.title,decks.approval,decks.notes
```
Ranks audio-bearing Spanish decks by approval rate and narrows the JSON to just title, approval, and note count.
### Compare three anatomy decks
```bash
ankiweb-pp-cli compare 241428882 815543631 1713698257 --agent
```
One table of approval rate, notes, audio/image coverage, and freshness across the three deck ids.
### What anatomy decks are new this week
```bash
ankiweb-pp-cli watch anatomy --since-last-sync --agent
```
Diffs the current catalog against your last sync and lists only new or changed decks.
### Topic briefing
```bash
ankiweb-pp-cli brief japanese --agent
```
Top decks by approval, audio coverage percentage, the freshest deck, and new-since-sync count in one digest.
## Auth Setup
AnkiWeb uses a session cookie, not an API key. Run `auth login --chrome` to import your logged-in ankiweb.net session, or set ANKIWEB_COOKIES. Public shared-deck search and info need no login.
Run `ankiweb-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 stRelated in General
modeling-omnistudio-epc-catalog
IncludedSalesforce Industries CME EPC product-modeling skill for Product2-based catalog creation. Use when creating EPC products, configuring product attributes, building offer bundles with Product Child Items, or reviewing EPC DataPack JSON metadata for product catalog changes. TRIGGER when: user creates or updates Product2 EPC records, AttributeAssignment payloads, AttributeMetadata/AttributeDefaultValues, Offer bundles, or ProductChildItem relationships. DO NOT TRIGGER when: designing OmniScripts/FlexCards/Integration Procedures (use building-omnistudio-omniscript, building-omnistudio-flexcard, or building-omnistudio-integration-procedure), implementing Apex business logic (use generating-apex), or troubleshooting deployment pipelines (use deploying-metadata).
relationship-science-coach
IncludedUse this skill for direct, practical adult relationship coaching: couples conflict, repair, trust, marriage, dating, flirting, attachment patterns, emotional connection, sex, desire differences, eroticism, kink negotiation, affection, love languages, breakups, and long-term passion. Draw on Gottman, EFT and Hold Me Tight, attachment science, modern sex research, Perel, Nagoski, Kerner, Schnarch, Love and Stosny, and flexible love-language tools. Be concrete and low-hedge. Redirect only for imminent danger, abuse, coercive control, minors, non-consent, self-harm, stalking, or medical/legal/psychiatric decisions.
building-sf-integrations
IncludedSalesforce integration architecture and runtime plumbing with 120-point scoring. Use this skill to set up Named Credentials, External Credentials, External Services, REST/SOAP callout patterns, Platform Events, and Change Data Capture. TRIGGER when: user sets up Named Credentials, External Services, REST/SOAP callouts, Platform Events, CDC, or touches .namedCredential-meta.xml files. DO NOT TRIGGER when: Connected App/OAuth config (use configuring-connected-apps), Apex-only logic (use generating-apex), or data import/export (use handling-sf-data).
venue-templates
IncludedAccess comprehensive LaTeX templates, formatting requirements, and submission guidelines for major scientific publication venues (Nature, Science, PLOS, IEEE, ACM), academic conferences (NeurIPS, ICML, CVPR, CHI), research posters, and grant proposals (NSF, NIH, DOE, DARPA). This skill should be used when preparing manuscripts for journal submission, conference papers, research posters, or grant proposals and need venue-specific formatting requirements and templates.
let-fate-decide
IncludedDraws the 12 Houses of the Zodiac Tarot spread to inject entropy into planning when prompts are vague, ambiguous, or casually delegated. Interprets the spread to guide next steps. Use when the user says 'let fate decide', 'YOLO', 'whatever', 'idk', or other nonchalant phrases, makes Yu-Gi-Oh references, or when you are about to arbitrarily pick between multiple reasonable approaches. Prefer over ask-questions-if-underspecified when the user's tone is casual or playful rather than precision-seeking.
net-ops
IncludedCross-platform network troubleshooting (Windows, macOS, Linux) via local or remote shell. Use for: DNS broken, can't resolve hostnames, nslookup/dig works but apps fail, NRPT, WFP, scutil, /etc/resolver, systemd-resolved, /etc/resolv.conf, NetworkManager, VPN DNS leak residue (ProtonVPN/Mullvad/WireGuard/AnyConnect), AV/firewall blocking DNS or DoH, Tailscale DNS interaction, intermittent connectivity, remote diagnostics over SSH.