CLI tool for Suno AI Music Generation via AceDataCloud API
Project description
Suno CLI
A command-line tool for AI music generation using Suno through the AceDataCloud API.
Generate AI music, lyrics, and manage audio projects directly from your terminal — no MCP client required.
Features
- Music Generation — Generate from prompts, custom lyrics, extend, cover, remaster, concat
- Lyrics — Generate lyrics, mashup, optimize style descriptions
- Media Conversion — Get MP4, WAV, MIDI, timing, extract vocals
- Task Management — Query tasks, batch query, wait with polling
- Rich Output — Beautiful terminal tables and panels via Rich
- JSON Mode — Machine-readable output with
--jsonfor piping - File Input — Read lyrics from files with
@filenamesyntax
Quick Start
1. Get API Token
Get your API token from AceDataCloud Platform:
- Sign up or log in
- Navigate to Suno Audios API
- Click "Acquire" to get your token
2. Install
# Install with pip
pip install suno-cli
# Or with uv (recommended)
uv pip install suno-cli
# Or from source
git clone https://github.com/AceDataCloud/SunoCli.git
cd SunoCli
pip install -e .
3. Configure
# Set your API token
export ACEDATACLOUD_API_TOKEN=your_token_here
# Or use .env file
cp .env.example .env
# Edit .env with your token
4. Use
# Generate music from a prompt
suno generate "A happy birthday song with acoustic guitar"
# Generate with custom lyrics
suno custom -l "[Verse]\nHello world\n[Chorus]\nLa la la" -t "Hello" -s "pop, upbeat"
# Read lyrics from a file
suno custom -l @lyrics.txt -t "My Song" -s "rock, powerful"
# Generate lyrics
suno lyrics "A love song about the ocean at sunset"
# Check task status
suno task <task-id>
# Wait for completion with polling
suno wait <task-id> --interval 5
# Get MP4 video
suno mp4 <audio-id>
# List available models
suno models
Commands
Music Generation
| Command | Description |
|---|---|
suno generate <prompt> |
Generate music from a text prompt (Inspiration Mode) |
suno custom |
Generate with custom lyrics, title, and style |
suno extend <audio_id> |
Extend an existing song from a timestamp |
suno cover <audio_id> |
Create a cover/remix version |
suno remaster <audio_id> |
Remaster a song to improve quality |
suno concat <audio_id> |
Merge extended segments into complete audio |
suno generate-persona <audio_id> |
Generate music using a saved persona |
suno stems <audio_id> |
Separate a song into vocals + instrumental |
suno replace-section <audio_id> |
Replace a time range with new content |
suno upload-extend <audio_id> |
Extend uploaded audio with AI continuation |
suno upload-cover <audio_id> |
Create a cover of uploaded audio |
suno mashup <id1> <id2>... |
Blend multiple songs into a mashup |
Lyrics
| Command | Description |
|---|---|
suno lyrics <prompt> |
Generate song lyrics from a prompt |
suno mashup-lyrics |
Generate mashup lyrics from two sources |
suno optimize-style <prompt> |
Optimize a style description |
Media Conversion
| Command | Description |
|---|---|
suno mp4 <audio_id> |
Get MP4 video version |
suno wav <audio_id> |
Get lossless WAV format |
suno midi <audio_id> |
Get MIDI data |
suno timing <audio_id> |
Get timing/subtitle data |
suno vocals <audio_id> |
Extract vocal track |
Task Management
| Command | Description |
|---|---|
suno task <task_id> |
Query a single task status |
suno tasks <id1> <id2>... |
Query multiple tasks at once |
suno wait <task_id> |
Wait for task completion with polling |
Utilities
| Command | Description |
|---|---|
suno persona <audio_id> |
Create a saved voice style |
suno upload <audio_url> |
Upload external audio for processing |
suno models |
List available Suno models |
suno actions |
List available API actions |
suno lyric-format |
Show lyrics formatting guide |
suno config |
Show current configuration |
Global Options
--token TEXT API token (or set ACEDATACLOUD_API_TOKEN env var)
--version Show version
--help Show help message
Most commands support:
--json Output raw JSON (for piping/scripting)
--model TEXT Suno model version (default: chirp-v4-5)
Scripting & Piping
The --json flag outputs machine-readable JSON suitable for piping:
# Generate and extract task ID
TASK_ID=$(suno generate "rock song" --json | jq -r '.task_id')
# Wait for completion and get audio URL
suno wait $TASK_ID --json | jq -r '.data[0].audio_url'
# Batch generate from a file of prompts
while IFS= read -r prompt; do
suno generate "$prompt" --json >> results.jsonl
done < prompts.txt
Available Models
| Model | Version | Max Duration | Notes |
|---|---|---|---|
chirp-v5 |
V5 | 8 min | Latest, best quality |
chirp-v4-5-plus |
V4.5+ | 8 min | Enhanced quality |
chirp-v4-5 |
V4.5 | 4 min | Vocal gender control (default) |
chirp-v4 |
V4 | 150s | Stable |
chirp-v3-5 |
V3.5 | 120s | Fast |
chirp-v3-0 |
V3 | 120s | Legacy |
Configuration
Environment Variables
| Variable | Description | Default |
|---|---|---|
ACEDATACLOUD_API_TOKEN |
API token from AceDataCloud | Required |
ACEDATACLOUD_API_BASE_URL |
API base URL | https://api.acedata.cloud |
SUNO_DEFAULT_MODEL |
Default model | chirp-v4-5 |
SUNO_REQUEST_TIMEOUT |
Timeout in seconds | 1800 |
Development
Setup Development Environment
# Clone repository
git clone https://github.com/AceDataCloud/SunoCli.git
cd SunoCli
# Create virtual environment
python -m venv .venv
source .venv/bin/activate # or `.venv\Scripts\activate` on Windows
# Install with dev dependencies
pip install -e ".[dev,test]"
Run Tests
# Run unit tests
pytest
# Run with coverage
pytest --cov=suno_cli
# Run integration tests (requires API token)
pytest tests/test_integration.py -m integration
Code Quality
# Format code
ruff format .
# Lint code
ruff check .
# Type check
mypy suno_cli
Build & Publish
# Install build dependencies
pip install -e ".[release]"
# Build package
python -m build
# Upload to PyPI
twine upload dist/*
Docker
# Pull the image
docker pull ghcr.io/acedatacloud/suno-cli:latest
# Run a command
docker run --rm -e ACEDATACLOUD_API_TOKEN=your_token \
ghcr.io/acedatacloud/suno-cli generate "A happy song"
# Or use docker-compose
docker compose run --rm suno-cli generate "A happy song"
Project Structure
SunoCli/
├── suno_cli/ # Main package
│ ├── __init__.py
│ ├── __main__.py # python -m suno_cli entry point
│ ├── main.py # CLI entry point
│ ├── core/ # Core modules
│ │ ├── client.py # HTTP client for Suno API
│ │ ├── config.py # Configuration management
│ │ ├── exceptions.py # Custom exceptions
│ │ └── output.py # Rich terminal formatting
│ └── commands/ # CLI command groups
│ ├── generate.py # Music generation commands (12 commands)
│ ├── lyrics.py # Lyrics & style commands
│ ├── media.py # Media conversion commands
│ ├── persona.py # Persona & upload commands
│ ├── task.py # Task management commands
│ └── info.py # Info & utility commands
├── tests/ # Test suite (80+ tests)
├── .github/workflows/ # CI/CD (lint, test, publish to PyPI)
├── Dockerfile # Container image
├── deploy/ # Kubernetes deployment configs
├── .env.example # Environment template
├── pyproject.toml # Project configuration
└── README.md
Suno CLI vs MCP Suno
| Feature | Suno CLI | MCP Suno |
|---|---|---|
| Interface | Terminal commands | MCP protocol |
| Usage | Direct shell, scripts, CI/CD | Claude, VS Code, MCP clients |
| Output | Rich tables / JSON | Structured MCP responses |
| Automation | Shell scripts, piping | AI agent workflows |
| Install | pip install suno-cli |
pip install mcp-suno |
Both tools use the same AceDataCloud API and share the same API token.
API Reference
This tool wraps the AceDataCloud Suno API:
- Suno Audios API — Music generation
- Suno Lyrics API — Lyrics generation
- Suno Tasks API — Task queries
- Suno Persona API — Persona management
Contributing
Contributions are welcome! Please:
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing) - Open a Pull Request
License
MIT License - see LICENSE for details.
Links
- AceDataCloud Platform
- MCP Suno — MCP server version
- Suno Official
Made with ❤️ by AceDataCloud
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_cli-2026.3.17.1.tar.gz.
File metadata
- Download URL: suno_cli-2026.3.17.1.tar.gz
- Upload date:
- Size: 21.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
10c51adc010c7a5b8ce7c8e774b693b59ddfea27cf03223209671014a80a018c
|
|
| MD5 |
f6e66c60c3f233763fa37275ddabfffb
|
|
| BLAKE2b-256 |
7590036ab5d59203165abc7443b818224fdb3789f925f6ecef30587649829cfa
|
File details
Details for the file suno_cli-2026.3.17.1-py3-none-any.whl.
File metadata
- Download URL: suno_cli-2026.3.17.1-py3-none-any.whl
- Upload date:
- Size: 21.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9375f2d33b4f1919cd99e8f144982c9e90abe01a4447c21d16dd592a00c2f7e3
|
|
| MD5 |
d18c5a25b2d7668aafc9b20396994907
|
|
| BLAKE2b-256 |
6cfb01dcddab4ffe7a989401fad2820230c9732bf0a34796ffec833691240297
|