name: pp-suno
description: "The correct, offline-first Suno CLI — every feature the abandoned clients have, plus a local SQLite library Trigger phrases: generate a song with suno, make music with suno, search my suno library, download my suno tracks, download a wav from suno, organize my suno tracks into a workspace, what are my top suno songs, use suno, run suno."
author: "Matt Van Horn"
license: "Apache-2.0"
argument-hint: "
Suno — Printing Press CLI
Prerequisites: Install the CLI
This skill drives the suno-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. It defaults binaries to
$HOME/.local/binon macOS/Linux and%LOCALAPPDATA%\Programs\PrintingPress\binon Windows:npx -y @mvanhorn/printing-press-library install suno --cli-only - Verify:
suno-pp-cli --version - Ensure the reported install directory is on
$PATHfor 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.4 or newer). This installs into $GOPATH/bin (default $HOME/go/bin), so add that directory to $PATH instead:
go install github.com/mvanhorn/printing-press-library/library/media-and-entertainment/suno/cmd/suno-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.
Suno has no official API and every reverse-engineered client is abandoned and wrong in ways that matter today: broken pagination, broken cover, stale pre-2026 auth, no local persistence. This CLI is built from the current contract. It walks the real opaque feed cursor, sends the now-required cover title, tolerates the drifted billing schema, authenticates against the current auth.suno.com Clerk flow via your logged-in browser, and persists your whole library to local SQLite for offline grep, SQL, lineage, and analytics. Generate, extend, cover, remaster, stems, lyrics, WAV download, and workspaces, all with --json, --select, --dry-run, and typed exit codes.
When to Use This CLI
Use this CLI when an agent or script needs to generate Suno music programmatically, manage and search a personal Suno library offline, or run reproducible generate/poll/download pipelines with typed exit codes and JSON output. It is the right choice over the abandoned community wrappers because it tracks the current Suno contract and persists everything locally.
Unique Capabilities
These capabilities aren't available in any other tool for this API.
Local library no Suno tool has
grep— Find clips by remembered lyric, prompt, or tag phrases via local full-text search.Reach for this when an agent needs to locate a specific past song by its content, not its title.
suno-pp-cli grep "rain" --json --select id,title,tagsanalytics— Grouped roll-ups across your whole library: counts, average duration/bpm, total plays and upvotes by any clip field.Use this to see which models or settings produced your most-played tracks before the next session.
suno-pp-cli analytics --type clips --group-by model_name --jsonlineage— Render the iteration tree of a track: its extends, covers, and remixes, reconstructed from local links.Reach for this to trace which seed a finished song descended from across many variations.
suno-pp-cli lineage 7d869de4-9476-4a4d-a6f2-c0eec968a3e2 --jsontop— Ranked flat list of your best clips by plays, upvotes, or duration, with machine-readable output.Use this to pipe your strongest tracks into a publishing or playlist workflow.
suno-pp-cli top --by upvote_count --limit 10 --jsonsql— Run read-only SQL directly against your local synced clip store.Reach for this when an agent needs an arbitrary query no fixed command covers.
suno-pp-cli sql "SELECT title, duration FROM clips WHERE make_instrumental = 1 ORDER BY duration DESC LIMIT 5" --json
Reachability awareness
credits --forecast— Remaining credits plus your recent generation volume measured against Suno's captcha-throttle threshold.Use this before a batch session to judge how many more generations you can run before hCaptcha kicks in.
suno-pp-cli credits --forecast --json
Command Reference
billing — Account credits, plan, and available models
suno-pp-cli billing— Show credits, plan, and modelssuno-pp-cli billing eligible-discounts— Show discounts you're eligible forsuno-pp-cli billing usage-plan— Show the plan comparison tablesuno-pp-cli billing usage-plan-faq— Show plan/usage FAQ
clips — Your Suno songs (clips) — list, fetch, manage
suno-pp-cli clips list— List your library (walks the opaque next_cursor; use --all to drain). Shows aworkspacecolumn from the local membership index.suno-pp-cli clips get— Fetch clip(s) by ID (comma-separated; Suno batches 2 at a time)suno-pp-cli clips set <clip_id>— Update a clip's title, caption, or lyricssuno-pp-cli clips publish <clip_id>— Toggle a clip public or privatesuno-pp-cli clips delete <clip_id>…— Trash (or, with--undo, restore) one or more clipssuno-pp-cli clips timed-lyrics <clip_id>— Word-level timestamped lyrics for a clipsuno-pp-cli clips stems <clip_id>— Separate a clip into stems (vocals + instruments)suno-pp-cli clips convert-wav <clip_id>— Trigger WAV (lossless) conversion (Pro/Premier); poll wav-urlsuno-pp-cli clips wav-url <clip_id>— Get the WAV download URL (null until conversion finishes)suno-pp-cli clips attribution <clip_id>— Show a clip's sample/attribution infosuno-pp-cli clips comments <clip_id>— List comments on a clipsuno-pp-cli clips parent <clip_id>— Show a clip's parent (the clip it was derived from)suno-pp-cli clips similar <clip_id>— Find clips similar to a given clipsuno-pp-cli clips direct-children-count <clip_ids>— Count direct children (extends/covers)
generate — Music, lyrics, and video generation jobs
suno-pp-cli generate create— Generate a custom song from lyrics (captcha-gated).--variation high|normal|subtle,--project <id>.suno-pp-cli generate describe— Description-driven (inspiration) generation.--variation,--instrumental.
All captcha-gated generate commands accept --wait-for-gate (with --gate-timeout, default 30m): when Suno's adaptive gate is tripped (HTTP 422 token_validation_failed), the command backs off and retries until the gate reopens or the timeout elapses. Off by default. It composes with the auto-solver — the solver runs first and --wait-for-gate rides out any residual gate, while under --no-captcha it drives the passive, no-browser fallback on its own. In --agent/JSON mode a gate failure is emitted as a structured envelope on stdout with error_type: "captcha_required" and retriable: true, so agents branch on a field rather than parsing prose.
suno-pp-cli generate extend <clip_id>— Extend a clip from a timestampsuno-pp-cli generate cover <clip_id>— Cover / restyle a clipsuno-pp-cli generate remaster <clip_id>— Remaster a clipsuno-pp-cli generate concat— Finalize/concatenate an extended clip into a full songsuno-pp-cli generate lyrics— Submit a lyrics-generation job (returns an id to poll)suno-pp-cli generate lyrics-status <id>— Poll a lyrics-generation job by idsuno-pp-cli generate video-status <id>— Check video-generation status for a clip
persona — Voice personas
suno-pp-cli persona get <persona_id>— View a voice personasuno-pp-cli persona usage— Show how many clips use each persona (and which are orphans)
project — Workspaces (Suno 'projects') — organize your tracks into collections
suno-pp-cli project list— List your workspacessuno-pp-cli project get <project_id>— Show a workspace and its clipssuno-pp-cli project create— Create a new workspacesuno-pp-cli project rename <project_id>— Rename a workspacesuno-pp-cli project trash— Trash (or restore) a workspacesuno-pp-cli project default— Show your default workspacesuno-pp-cli project pinned-clips— List clips pinned to your default workspacesuno-pp-cli project add <project_id>— Add clip(s) to a workspace (repeatable--clip)suno-pp-cli project remove <project_id>— Remove clip(s) from a workspace (repeatable--clip)
playlist / trending / user / notification — library and account reads
suno-pp-cli playlist list— List your playlistssuno-pp-cli trending list— Show trending clipssuno-pp-cli user config— Show your user configsuno-pp-cli user personalization— Show your personalization settingssuno-pp-cli user personalization-memory— Show your personalization memorysuno-pp-cli notification list— List your notificationssuno-pp-cli notification badge-count— Show unread notification badge count
skill — Install the Suno CLI as a coding-agent skill
suno-pp-cli skill install— Write this SKILL into Claude/Codex/Cursor locations.--agent claude|codex|cursor|all,--print,--path <file>,--force.
Restored local & utility commands — parity with the 2026-05-15 build; these coexist with the novel commands above
suno-pp-cli vibes save <name>— Save a local generation recipe (tags/prompt-template/persona/mv); replay withvibes use <name> [topic]. Alsovibes list|get|delete.suno-pp-cli burn --by tag|persona|model|hour— Aggregate estimated generation credits across your local librarysuno-pp-cli budget set daily|monthly <N>— Set a local credit cap;budget showreports spend; caps block over-limitgeneratecalls.budget clearremoves the cap.suno-pp-cli sessions— Group synced clips into 30-minute-gap working sessionssuno-pp-cli ship <clip-id>— Export an editor-ready bundle (audio + video + cover +.lrc+.jsonsidecar)suno-pp-cli tail <resource> --interval 10s— Poll the API and stream changes as NDJSONsuno-pp-cli tree <clip-id>— Render a clip's local lineage tree (legacy view; see alsolineage)suno-pp-cli custom-model— List pending custom-model training jobs
Finding the right command
When you know what you want to do but not which command does it, ask the CLI directly:
suno-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
Generate a custom song and wait for it
suno-pp-cli generate create --title "Night Drive" --tags "synthwave, retro" --lyrics "Neon lights on wet asphalt" --token hc_demo_token --wait --json
Submits a custom generation, polls until complete, and prints the finished clip as JSON. Omit --token to let the CLI auto-solve via the captcha profile, or supply a pre-solved token to skip the browser.
Pull a deeply nested clip and select only what you need
suno-pp-cli clips get --ids 7d869de4-9476-4a4d-a6f2-c0eec968a3e2 --agent --select id,title,status,audio_url,metadata.duration,metadata.tags
Fetches a clip and narrows the verbose nested payload to just the fields an agent needs, saving context.
Find and rank instrumentals offline
suno-pp-cli sql "SELECT title, duration FROM clips WHERE make_instrumental = 1 ORDER BY duration DESC LIMIT 5" --json
Queries the local store directly for your longest instrumental tracks, no API call.
Check throttle headroom before a session
suno-pp-cli credits --forecast --json
Shows remaining credits and recent generation volume against the captcha-throttle threshold.
Organize tracks into a workspace
suno-pp-cli workspace add ws_3f2a91 --clip clip_a1b2 --clip clip_c3d4
Adds clips to a Suno workspace (project) so they stay organized on suno.com.
Download a lossless WAV
suno-pp-cli download clip_a1b2c3 --format wav --out ./tracks
Triggers WAV conversion, polls until ready, and saves the lossless file (Pro/Premier).
Auth Setup
Suno uses Clerk session auth (auth.suno.com). Run suno-pp-cli auth login --chrome to capture your logged-in session cookie from Chrome; the CLI mints and refreshes the short-lived JWT for you. No password or API key is stored. Music generation is attempted optimistically with no token. Suno gates generation adaptively (an hCaptcha anti-bot challenge that usually fires only after sustained use), so many generations succeed outright. When the gate does trip, the CLI automatically solves it using a dedicated piloted-Chrome profile — run suno-pp-cli auth captcha login --profile <name> to sign a profile in, then pass --captcha-profile <name> on any gated command to select that account. Under --agent/--no-input the visible browser fallback is suppressed and a structured {"error_type":"captcha_required","retriable":true} envelope is emitted on stdout (exit 2). To skip the auto-solver entirely, pass --no-captcha or supply a pre-solved token with --token. All read, library, and metadata commands never need a captcha.
Run suno-pp-cli doctor to verify setup. Add --probe-gate to check the live generation gate specifically: the default health check only proves the billing API is reachable, which stays green even while generation is gated. doctor --probe-gate reports tripped (the adaptive hCaptcha gate is active) or open. WARNING: it issues a real generation — free when the gate is tripped, but it creates a clip and spends credits when the gate is open (the probe clip is best-effort trashed).
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:suno-pp-cli clips list --agent --select id,name,statusPreviewable —
--dry-runshows the request without sendingOffline-friendly — sync/search commands can use the local SQLite store when available
Non-interactive — never prompts, every input is a flag
Explicit retries — use
--idempotentonly when an already-existing create should count as success
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 AND no machine-format flag (--json, --csv, --compact, --quiet, --plain, --select) is set — piped/agent consumers and explicit-format runs get pure JSON on stdout.
Agent Feedback
When you (or the agent) notice something off about this CLI, record it:
suno-pp-cli feedback "the --since flag is inclusive but docs say exclusive"
suno-pp-cli feedback --stdin < notes.txt
suno-pp-cli feedback list --json --limit 10
Entries are stored locally at ~/.local/share/suno-pp-cli/feedback.jsonl. They are never POSTed unless SUNO_FEEDBACK_ENDPOINT is set AND either --send is passed or SUNO_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.
suno-pp-cli profile save briefing --json
suno-pp-cli --profile briefing clips list
suno-pp-cli profile list --json
suno-pp-cli profile show briefing
suno-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→ showsuno-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/media-and-entertainment/suno/cmd/suno-pp-mcp@latest - Register with Claude Code:
claude mcp add suno-pp-mcp -- suno-pp-mcp - Verify:
claude mcp list
Direct Use
- Check if installed:
which suno-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:suno-pp-cli <command> [subcommand] [args] --agent - If ambiguous, drill into subcommand help:
suno-pp-cli <command> --help.