gumroad
Use the `gumroad` CLI to look up and manage Gumroad data from the terminal. Trigger when the user asks about Gumroad products, files, file uploads, attachments, sales, subscribers, licenses, payouts, offer codes, webhooks, or any Gumroad data lookup. Also trigger on "check my Gum
What it does
gumroad CLI
Use gumroad (Gumroad CLI) to query and manage Gumroad data.
Agent invariants
Always follow these rules:
- Always pass
--no-inputto prevent interactive prompts from blocking. - Always pass
--jsonfor programmatic access. - Use
--json --jq <expr>together to extract exactly what you need. - For operations that can prompt for confirmation (delete, refund,
files abort,files completereplay, or product updates that remove files), add--yesto skip confirmation. - Pass
--quietto suppress spinners and status messages. - Pass
--dry-runto preview mutating requests without executing them. - Use
--page-delay 200mswith--allto avoid rate limits on large datasets. - Prices are in whole currency units (e.g.
--price 10.00for $10), not cents. The CLI converts internally. Use--currency eurto change currency. - Products are created as drafts — use
gumroad products publish <id>to make them live. - If a command fails with a seller auth error, tell the user to run
gumroad auth logininteractively — agents cannot do this step. - For admin commands in agents/CI, pass
--non-interactiveand setGUMROAD_ADMIN_TOKEN; interactive shells can store an admin token withgumroad auth login.
Response shapes
Responses are wrapped in {"success": true, ...} with resource-specific keys:
user→.userproducts list→.products[]products view→.productsales list→.sales[]sales view→.salepayouts list→.payouts[],payouts view/upcoming→.payoutsubscribers list→.subscribers[],subscribers view→.subscriberlicenses verify→.purchaseoffer-codes list→.offer_codes[]variant-categories list→.variant_categories[]variants list→.variants[]files upload/files complete→.file_urlwebhooks list→.resource_subscriptions[]admin users info→.useradmin users affiliates→.affiliates[]admin users comments list→.comments[]admin users comments add→.commentadmin users compliance→.compliance_info,.info_requests[]admin users radar→.radar_stats,.recent_efws[]admin users purchases→.purchases[]admin users related→.related_users[],.truncated,.per_signal_limitadmin purchases view→.purchaseadmin purchases search→.purchases[],.has_more,.limitadmin purchases lookup→.purchases[]admin products list→.products[],admin products view→.product
Admin pagination models differ by command:
- Cursor-paginated:
admin users affiliates,admin users comments list,admin users radar,admin users purchases, andadmin purchases lookupreturn.pagination.nextas a cursor string. Pass it back with--cursor. - Page-paginated:
admin products listreturns.pagination.nextas an integer page number. Pass it back with--page; use--per-pagefor page size. - Capped, not continuable:
admin users relatedreturns at most 50 related users per signal. Always inspect.truncated; when any signal istrue, the result hit the cap and there is no cursor/page to fetch the rest. - Capped, not continuable:
admin purchases searchreturns.has_morewhen the server capped results.--limitis server-capped at 25 and there is no continuation token.
Commands
auth — Manage authentication
# Check auth (do this first if unsure)
gumroad auth status --no-input
# Login requires interactive input — tell the user to run it themselves
# gumroad auth login
# Logout
gumroad auth logout --yes --no-input
user — Account info
gumroad user --json --no-input
gumroad user --json --jq '.user.email' --no-input
admin — Internal admin API
# Admin commands need internal admin auth.
# In agents/CI, set GUMROAD_ADMIN_TOKEN and pass --non-interactive.
# Inspect user identity, sign-in, social, risk, payout, and watchlist state
gumroad admin users info --email seller@example.com --json --non-interactive --no-input
# Review affiliate relationships
gumroad admin users affiliates --user-id 2245593582708 --direction granted --limit 50 --json --non-interactive --no-input
gumroad admin users affiliates --email seller@example.com --direction received --cursor cur-next --json --non-interactive --no-input
# Read and add admin comments
gumroad admin users comments list --user-id 2245593582708 --type note --limit 50 --json --non-interactive --no-input
gumroad admin users comments add --user-id 2245593582708 --content "VAT exempt confirmed" --yes --json --non-interactive --no-input
# Inspect compliance, Radar risk, and buyer history
gumroad admin users compliance --user-id 2245593582708 --json --non-interactive --no-input
gumroad admin users radar --user-id 2245593582708 --limit 50 --json --non-interactive --no-input
gumroad admin users purchases --user-id 2245593582708 --status successful --has-early-fraud-warning=false --limit 50 --json --non-interactive --no-input
# Find related accounts by risk signals
gumroad admin users related --email seller@example.com --signal ip --signal payment_address --json --non-interactive --no-input
gumroad admin users related --email seller@example.com --json --jq '{related_users, truncated, per_signal_limit}' --non-interactive --no-input
# Inspect purchase and product fraud context
gumroad admin purchases view <purchase-id> --with-clusters --json --non-interactive --no-input
gumroad admin purchases search --email buyer@example.com --json --jq '{purchases, has_more, limit}' --non-interactive --no-input
gumroad admin purchases lookup --stripe-fingerprint fp_abc --limit 25 --json --non-interactive --no-input
gumroad admin products list --email seller@example.com --page 2 --per-page 25 --json --non-interactive --no-input
gumroad admin products view <product-id> --with-fraud-context --json --non-interactive --no-input
# Watchlist state does not pause payouts or change user risk state
gumroad admin users watch --user-id 2245593582708 --expected-email seller@example.com --revenue-threshold 200 --note "Review next buyers" --yes --json --non-interactive --no-input
gumroad admin users update-watch --user-id 2245593582708 --expected-email seller@example.com --revenue-threshold 500 --yes --json --non-interactive --no-input
gumroad admin users update-watch --user-id 2245593582708 --expected-email seller@example.com --revenue-threshold 500 --clear-note --yes --json --non-interactive --no-input
gumroad admin users unwatch --user-id 2245593582708 --expected-email seller@example.com --yes --json --non-interactive --no-input
products — Manage products
# List all products
gumroad products list --json --no-input
# View a product
gumroad products view <id> --json --no-input
# Create a product (created as draft)
gumroad products create --name "Art Pack" --price 10.00 --json --no-input
gumroad products create --name "Art Pack" --price 10.00 --file ./pack.zip --file-name "Art Pack.zip" --json --no-input
gumroad products create --name "Newsletter" --type membership --subscription-duration monthly --json --no-input
gumroad products create --name "E-Book" --type ebook --price 5 --tag art --tag digital --json --no-input
# Update a product
gumroad products update <id> --name "New Name" --json --no-input
gumroad products update <id> --price 15.00 --currency eur --json --no-input
gumroad products update <id> --file ./pack.zip --json --no-input
gumroad products update <id> --replace-files --keep-file file_123 --file ./new-pack.zip --yes --json --no-input
gumroad products update <id> --remove-file file_456 --yes --json --no-input
# Publish / unpublish
gumroad products publish <id> --json --no-input
gumroad products unpublish <id> --json --no-input
# Delete (destructive — needs --yes)
gumroad products delete <id> --yes --json --no-input
# List SKUs for a product
gumroad products skus <id> --json --no-input
Create flags: --name (required), --price, --type (digital|course|ebook|membership|bundle|coffee|call|commission), --currency, --pay-what-you-want, --suggested-price, --description, --custom-summary, --custom-permalink, --custom-receipt, --max-purchase-count, --taxonomy-id, --tag (repeatable), --file (repeatable), --file-name (repeatable, aligned to --file), --file-description (repeatable, aligned to --file).
Update flags: --file (repeatable), --file-name, --file-description, --remove-file (repeatable), --replace-files, --keep-file (repeatable with --replace-files). Updates preserve existing files by default unless --replace-files is set.
files — Upload and recover file attachments
# Upload a file and print the canonical Gumroad URL
gumroad files upload ./pack.zip --json --no-input
gumroad files upload ./pack.zip --name "Art Pack.zip" --json --no-input
# Finalize a saved recovery manifest after a state-unknown upload
gumroad files complete --recovery recovery.json --yes --json --no-input
jq '.error.recovery' err.json | gumroad files complete --recovery - --yes --json --no-input
# Abort an orphaned multipart upload
gumroad files abort --upload-id up-123 --key attachments/u/k/original/pack.zip --yes --json --no-input
files upload and files complete both return .file_url. When a JSON upload fails with recovery details, reuse .error.recovery with files complete to finish it or files abort to reclaim the orphaned multipart upload.
sales — Manage sales
# List sales (paginated)
gumroad sales list --json --no-input
gumroad sales list --product <id> --after 2024-01-01 --json --no-input
gumroad sales list --email user@example.com --json --no-input
gumroad sales list --all --json --no-input
# Find a sale by email
gumroad sales list --json --jq '.sales[] | select(.email == "user@example.com")' --no-input
# View a sale
gumroad sales view <id> --json --no-input
# Refund (destructive — needs --yes)
gumroad sales refund <id> --yes --json --no-input
gumroad sales refund <id> --amount 5.00 --yes --json --no-input
# Resend receipt
gumroad sales resend-receipt <id> --json --no-input
List filters: --product, --order, --email, --after (YYYY-MM-DD), --before (YYYY-MM-DD), --all, --page-key.
payouts — View payouts
# List payouts
gumroad payouts list --json --no-input
gumroad payouts list --after 2024-01-01 --before 2024-12-31 --json --no-input
gumroad payouts list --all --json --no-input
# View a payout
gumroad payouts view <id> --json --no-input
gumroad payouts view <id> --include-transactions --json --no-input
# Upcoming payout
gumroad payouts upcoming --json --no-input
List filters: --after, --before, --all, --page-key, --no-upcoming.
View flags: --include-transactions, --no-sales.
subscribers — View subscribers
gumroad subscribers list --product <id> --json --no-input
gumroad subscribers list --product <id> --email user@example.com --json --no-input
gumroad subscribers list --product <id> --all --json --no-input
gumroad subscribers view <id> --json --no-input
List flags: --product (required), --email, --all, --page-key.
licenses — Manage license keys
License keys are passed via stdin. Never pass keys as command-line arguments.
# Verify without incrementing use count
echo "$LICENSE_KEY" | gumroad licenses verify --product <id> --no-increment --json --no-input
# Verify (increments use count)
echo "$LICENSE_KEY" | gumroad licenses verify --product <id> --json --no-input
# Enable / disable
echo "$LICENSE_KEY" | gumroad licenses enable --product <id> --json --no-input
echo "$LICENSE_KEY" | gumroad licenses disable --product <id> --json --no-input
# Decrement use count
echo "$LICENSE_KEY" | gumroad licenses decrement --product <id> --json --no-input
# Rotate (regenerate) key
echo "$LICENSE_KEY" | gumroad licenses rotate --product <id> --json --no-input
All subcommands require --product <id>. Key comes from stdin.
offer-codes — Manage discount codes
# List offer codes for a product
gumroad offer-codes list --product <id> --json --no-input
# Create (percent or flat, not both)
gumroad offer-codes create --product <id> --name SAVE10 --percent-off 10 --json --no-input
gumroad offer-codes create --product <id> --name FLAT5 --amount 5.00 --json --no-input
# View / update / delete
gumroad offer-codes view <code_id> --product <id> --json --no-input
gumroad offer-codes update <code_id> --product <id> --max-purchase-count 100 --json --no-input
gumroad offer-codes delete <code_id> --product <id> --yes --json --no-input
Create flags: --product (required), --name (required), --percent-off OR --amount, --max-purchase-count, --universal.
variant-categories — Manage variant categories
gumroad variant-categories list --product <id> --json --no-input
gumroad variant-categories create --product <id> --title "Size" --json --no-input
gumroad variant-categories view <cat_id> --product <id> --json --no-input
gumroad variant-categories update <cat_id> --product <id> --title "Color" --json --no-input
gumroad variant-categories delete <cat_id> --product <id> --yes --json --no-input
variants — Manage variants within a category
gumroad variants list --product <id> --category <cat_id> --json --no-input
gumroad variants create --product <id> --category <cat_id> --name "Large" --json --no-input
gumroad variants create --product <id> --category <cat_id> --name "XL" --price-difference 5.00 --json --no-input
gumroad variants view <var_id> --product <id> --category <cat_id> --json --no-input
gumroad variants update <var_id> --product <id> --category <cat_id> --name "Medium" --json --no-input
gumroad variants delete <var_id> --product <id> --category <cat_id> --yes --json --no-input
All subcommands require --product and --category.
custom-fields — Manage custom fields
Custom fields are keyed by name, not ID.
gumroad custom-fields list --product <id> --json --no-input
gumroad custom-fields create --product <id> --name "Company" --required --json --no-input
gumroad custom-fields update --product <id> --name "Company" --required --json --no-input
gumroad custom-fields delete --product <id> --name "Company" --yes --json --no-input
webhooks — Manage webhooks
# List (--resource is required)
gumroad webhooks list --resource sale --json --no-input
# Create
gumroad webhooks create --resource sale --url https://example.com/hook --json --no-input
# Delete
gumroad webhooks delete <id> --yes --json --no-input
Tips
- Use
--allwithsales list,subscribers list,payouts listto fetch every page automatically. - Use
--plainfor tab-separated output suitable forcut,awk, and other Unix tools. - Run
gumroad <command> --helpfor full flag details on any command.
Capabilities
Install
Quality
deterministic score 0.45 from registry signals: · indexed on github topic:agent-skills · 9 github stars · SKILL.md body (14,909 chars)