From cli-printing-press
Browses catalog and installs pre-built Go CLI tools for popular APIs like Stripe. Requires printing-press binary and Go 1.26+. Deprecated; superseded by /printing-press.
npx claudepluginhub mvanhorn/cli-printing-press --plugin cli-printing-pressThis skill is limited to using the following tools:
> **Deprecated:** This skill is superseded by the main `/printing-press` skill, which now checks the built-in catalog automatically. Use `/printing-press <API>` instead. For browsing the catalog, use `printing-press catalog list` in your terminal.
Publishes generated CLIs from local printing-press library to printing-press-library GitHub repo via pull request. Handles mirrors, manifests, and PR creation.
Builds, extends, and reviews Go CLI tools using Cobra and Viper for command structure, flags, config layering, version embedding, testing, and shell integration.
Builds fast CLI tools in Node.js, Python, Go: argument parsing, subcommands, interactive prompts, progress bars, shell completions.
Share bugs, ideas, or general feedback.
Deprecated: This skill is superseded by the main
/printing-pressskill, which now checks the built-in catalog automatically. Use/printing-press <API>instead. For browsing the catalog, useprinting-press catalog listin your terminal.
Browse and install pre-built Go CLIs for popular APIs.
/printing-press-catalog
/printing-press-catalog install stripe
/printing-press-catalog search auth
printing-press binary on PATH (install with go install github.com/mvanhorn/cli-printing-press/v4/cmd/printing-press@latest)Before any other commands, run the setup contract to verify the printing-press binary is on PATH and initialize scope variables:
# min-binary-version: 4.0.0
# Derive scope first — needed for local build detection
_scope_dir="$(git rev-parse --show-toplevel 2>/dev/null || echo "$PWD")"
_scope_dir="$(cd "$_scope_dir" && pwd -P)"
# Prefer local build when running from inside the printing-press repo.
if [ -x "$_scope_dir/printing-press" ] && [ -d "$_scope_dir/cmd/printing-press" ]; then
export PATH="$_scope_dir:$PATH"
echo "Using local build: $_scope_dir/printing-press"
elif ! command -v printing-press >/dev/null 2>&1; then
if [ -x "$HOME/go/bin/printing-press" ]; then
echo "printing-press found at ~/go/bin/printing-press but not on PATH."
echo "Add GOPATH/bin to your PATH: export PATH=\"\$HOME/go/bin:\$PATH\""
else
echo "printing-press binary not found."
echo "Install with: go install github.com/mvanhorn/cli-printing-press/v4/cmd/printing-press@latest"
fi
return 1 2>/dev/null || exit 1
fi
PRESS_BASE="$(basename "$_scope_dir" | tr '[:upper:]' '[:lower:]' | sed -E 's/[^a-z0-9_-]/-/g; s/^-+//; s/-+$//')"
if [ -z "$PRESS_BASE" ]; then
PRESS_BASE="workspace"
fi
PRESS_SCOPE="$PRESS_BASE-$(printf '%s' "$_scope_dir" | shasum -a 256 | cut -c1-8)"
PRESS_HOME="$HOME/printing-press"
PRESS_RUNSTATE="$PRESS_HOME/.runstate/$PRESS_SCOPE"
PRESS_LIBRARY="$PRESS_HOME/library"
mkdir -p "$PRESS_RUNSTATE" "$PRESS_LIBRARY"
After running the setup contract, check binary version compatibility. Read the min-binary-version field from this skill's YAML frontmatter. Run printing-press version --json and parse the version from the output. Compare it to min-binary-version using semver rules. If the installed binary is older than the minimum, stop immediately and tell the user: "printing-press binary vX.Y.Z is older than the minimum required vA.B.C. Run go install github.com/mvanhorn/cli-printing-press/v4/cmd/printing-press@latest to update."
Generated CLIs are published to $PRESS_LIBRARY/, not to the repo.
When invoked with no arguments, list all available CLIs grouped by category.
Available CLIs (12 entries):
Payments:
stripe - Payment processing and financial infrastructure API
square - Payment processing and commerce API
Auth:
stytch - Authentication and user management API
Email:
sendgrid - Email delivery and marketing API
Communication:
discord - Chat and community platform API
twilio - Communication APIs for SMS, voice, and messaging
front - Customer communication platform API
Developer Tools:
github - Software development platform API
digitalocean - Cloud infrastructure and developer platform API
Project Management:
asana - Work management and project tracking API
CRM:
hubspot - CRM contacts API
Example:
petstore - Canonical OpenAPI example
Install any CLI: /printing-press-catalog install <name>
When invoked with install <name>:
CATALOG_TMP_DIR="/tmp/printing-press/catalog"
mkdir -p "$CATALOG_TMP_DIR"
SPEC_TMP="$(mktemp "$CATALOG_TMP_DIR/<name>-spec-XXXXXX.yaml")"
curl -sL -o "$SPEC_TMP" "<spec_url>"
OUTPUT_BASE="$PRESS_LIBRARY/<name>-pp-cli"
OUTPUT_DIR="$OUTPUT_BASE"
i=2
while [ -e "$OUTPUT_DIR" ]; do
OUTPUT_DIR="${OUTPUT_BASE}-$i"
i=$((i + 1))
done
printing-press generate \
--spec "$SPEC_TMP" \
--output "$OUTPUT_DIR" \
--validate
Generated <name>-pp-cli with X resources.
Try it:
cd "$OUTPUT_DIR"
go install ./cmd/<name>-pp-cli
<name>-pp-cli --help
<name>-pp-cli doctor
When invoked with search <query>: