Archive your Suno music library: audio, cover art, and complete metadata, with incremental sync
Project description
suno-archiver
Archive your entire Suno music library — MP3 audio, cover art, and full metadata — with one command.
Why
Suno's web UI only lets you download tracks one at a time. If you've generated more than a handful, pulling them all by hand is tedious-to-impossible. This tool grabs your entire library in one command — audio, cover art, and full metadata as JSON — organized on your own disk.
Useful if you:
- have a large library (hundreds or thousands of generations) and want it all local — for a DAW, a dataset, offline access, or your own bookkeeping. A 1,600-track pull is one run, not 1,600 clicks.
- want your data in a structured, scriptable form — every track's prompt, tags, model, and timestamps in JSON, plus a single
library_index.jsonyou can grep or query. - don't want to depend on the cloud staying put. Suno's Warner Music deal (early 2026) pulled free download access ahead of schedule; terms can change again. A local copy doesn't.
Run it on a schedule with --last-run and the archive stays current automatically.
Tested at scale. A full 1,668-track library spanning two years (2024–2026) archived in a single run — 5.7 GB, 99.9% success rate, no rate-limiting or throttling. The handful of missing files were dead/transient links on Suno's CDN, not failures of the tool — and a re-run picks them up.
What it grabs
| File | Details |
|---|---|
.mp3 |
Audio (Suno's MP3 stream) |
.jpg |
Cover art |
.json |
Full metadata — prompt, tags, lyrics, duration, model version, created/updated dates |
library_index.json |
All songs in one file, grep/jq-friendly |
--wav |
Optional: triggers Suno's lossless conversion and downloads the WAV alongside the MP3 (slower — one conversion request per song) |
Important
- Personal backup of your own creations only. Do not scrape other users' libraries.
- Audio downloads require a paid Suno plan (Pro or Premier). Metadata-only runs work on free plans.
- Undocumented API — Suno can change or break this at any time. Run
suno-archiver doctorif something stops working, and check for updates withpip install -U suno-archiver.
Install
pipx install suno-archiver # recommended: isolated environment
# or
pip install suno-archiver
Requires Python 3.9+.
Auth
Primary: just be logged in to suno.com in your browser
That's it. suno-archiver uses rookiepy to read your existing browser session cookie automatically. Works with Chrome, Brave, Firefox, Safari, Arc, Edge, and more — no manual steps needed.
suno-archiver # rookiepy finds your session automatically
Fallback: set SUNO_COOKIE manually
Use this if browser auto-detection fails (headless servers, CI, multiple profiles, or just for troubleshooting):
- Open suno.com in Chrome and make sure you're logged in.
- Open DevTools → Network tab → reload the page.
- Click any request to
clerk.suno.com(look forclient?__clerk_api_version=...). - Select the Cookies tab in the request detail panel.
- Find the
__clientcookie — it's a long three-segment JWT (looks likeeyJ...). - Copy its value.
# .env file or shell environment
SUNO_COOKIE=eyJhbGci... # paste the full __client value here
Then run suno-archiver doctor to confirm it's working.
Usage
suno-archiver # full archive: MP3s + covers + metadata
suno-archiver --wav # also WAVs (slower: conversion per song)
suno-archiver --last-run # only what's new since the last run
suno-archiver --since "2 weeks ago"
suno-archiver --dir ~/Music/suno_archive
suno-archiver doctor # diagnose auth/API issues
Re-runs are idempotent — existing files are skipped, so --last-run on a cron job keeps your archive current without re-downloading anything.
What lands on disk
suno_archive/
├── 2026-06/
│ ├── 2026-06-02_concrete-syncope_49291ca0.mp3
│ ├── 2026-06-02_concrete-syncope_49291ca0.jpg (cover art)
│ └── 2026-06-02_concrete-syncope_49291ca0.json (full metadata)
├── library_index.json (everything, searchable with jq/grep)
└── .suno-archiver-state.json
Songs are organized into YYYY-MM/ month folders. The state file records the last run timestamp for --last-run incremental syncs.
Resilient by design
Archiving thousands of files over an undocumented API means things will occasionally go wrong mid-run. The tool is built so that they don't cost you:
- Per-file errors never abort the run. A dead CDN link (403) or a transient hiccup (503) is counted and reported, then the run continues. You get a clear tally at the end:
3333 downloaded, 0 skipped, 3 errors. - Expired sessions self-heal. Suno's auth tokens are short-lived; the tool transparently re-mints them, and retries once on a 401 before giving up.
- Interrupted runs are safe. The
--last-runwatermark is only saved when a fetch completes cleanly — so a connection drop or a kill mid-run can never cause the next incremental sync to silently skip tracks. You just re-run. - Re-runs are free. Idempotent skipping means re-running after a partial failure costs nothing for already-downloaded files; only the gaps are retried.
If the tool ever stops working entirely (Suno changed their API), suno-archiver doctor tells you which layer broke — your login, the auth exchange, or the library endpoint — so you know whether to re-log-in or wait for an update.
Related
replicate-predictions-downloader — same idea for Replicate AI predictions: bulk-download all your generated outputs from Replicate's API.
License
MIT — see LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file suno_archiver-1.0.0.tar.gz.
File metadata
- Download URL: suno_archiver-1.0.0.tar.gz
- Upload date:
- Size: 35.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b3cdf266da93234d640ab26a4825fc3d4dd953a761fac5f16bc49fe4564d2838
|
|
| MD5 |
89840eea75660a998f65171513aa459d
|
|
| BLAKE2b-256 |
2ddcebdf0af3d75f7ba2fa765bd662552207e5842776fb740372ecd54b569eca
|
File details
Details for the file suno_archiver-1.0.0-py3-none-any.whl.
File metadata
- Download URL: suno_archiver-1.0.0-py3-none-any.whl
- Upload date:
- Size: 13.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5fa69f12119392b7ed9dae2c80e9b1493de676750880cbfa7b6cd5edfc350b1f
|
|
| MD5 |
711dca7370375f5777bb92640ed92b36
|
|
| BLAKE2b-256 |
e4045596788ed9baddc220fcd535a625f93611b4cc2cb72bab4250bee0184f20
|