Loading...
Loading...
Browse and install pre-built Go CLIs for popular APIs from the catalog
npx skill4agent add mvanhorn/cli-printing-press printing-press-catalogDeprecated: This skill is superseded by the mainskill, which now checks the built-in catalog automatically. Use/printing-pressinstead. For browsing the catalog, use/printing-press <API>in your terminal.printing-press catalog list
/printing-press-catalog
/printing-press-catalog install stripe
/printing-press-catalog search authprinting-pressgo install github.com/mvanhorn/cli-printing-press/v4/cmd/printing-press@latest# min-binary-version: 0.2.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"min-binary-versionprinting-press version --jsonmin-binary-versiongo install github.com/mvanhorn/cli-printing-press/v4/cmd/printing-press@latest$PRESS_LIBRARY/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>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" \
--validateGenerated <name>-pp-cli with X resources.
Try it:
cd "$OUTPUT_DIR"
go install ./cmd/<name>-pp-cli
<name>-pp-cli --help
<name>-pp-cli doctorsearch <query>