Operate SunoAPI through your OOMOL-connected account. This skill calls the sunoapi connector with the oo CLI; OOMOL injects credentials server-side, so you never handle raw tokens.
Assume the user has already installed the oo CLI, signed in, and connected SunoAPI. Do not run oo auth login or open the connection URL proactively — just run the action. Fall back to First-time setup only when a command actually fails with an auth or connection error.
1. Inspect the contract to get the authoritative input/output schema before building a payload:
oo connector schema "sunoapi" --action "<action_name>"
2. Run the action with a JSON payload that matches the input schema:
oo connector run "sunoapi" --action "<action_name>" --data '<json>' --json
--data takes a JSON object string or @path/to/file.json; omit it to send {}.{ "data": ..., "meta": { "executionId": "..." } }; the execution id lives under meta.executionId.Each action is listed below with a one-line description; actions that change state carry a [write] or [destructive] tag. Before constructing --data, fetch the action's live schema with oo connector schema to get its authoritative input fields.
add_instrumental — Submit a SunoAPI add instrumental task and return the task identifier. [write]add_vocals — Submit a SunoAPI add vocals task and return the task identifier. [write]boost_music_style — Boost a SunoAPI style prompt and return the generated style text.convert_to_wav_format — Submit a SunoAPI WAV conversion task and return the task identifier.create_music_video — Submit a SunoAPI music video task and return the task identifier. [write]extend_music — Submit a SunoAPI music extension task and return the task identifier.generate_lyrics — Submit a SunoAPI lyrics generation task and return the task identifier.generate_mashup — Submit a SunoAPI mashup task and return the task identifier.generate_midi — Submit a SunoAPI MIDI task and return the task identifier.generate_music — Submit a SunoAPI music generation task and return the task identifier.generate_music_cover — Submit a SunoAPI music cover task and return the task identifier.generate_persona — Submit a SunoAPI persona generation task and return the generated persona details.generate_sounds — Submit a SunoAPI sounds task and return the task identifier.get_lyrics_generation_details — Fetch SunoAPI lyrics generation details for a task.get_midi_generation_details — Fetch SunoAPI MIDI generation details for a task.get_music_cover_details — Fetch SunoAPI music cover details for a task.get_music_generation_details — Fetch SunoAPI music generation details for a task.get_music_video_details — Fetch SunoAPI music video details for a task.get_remaining_credits — Fetch the remaining SunoAPI credits for the authenticated account.get_timestamped_lyrics — Fetch SunoAPI timestamped lyrics for a track.get_vocal_separation_details — Fetch SunoAPI vocal separation details for a task.get_wav_conversion_details — Fetch SunoAPI WAV conversion details for a task.replace_music_section — Submit a SunoAPI section replacement task and return the task identifier. [write]separate_vocals_from_music — Separate vocals from music and return the submitted SunoAPI task identifier.upload_and_cover_audio — Submit a SunoAPI upload and cover task and return the task identifier. [write]upload_and_extend_audio — Submit a SunoAPI upload and extend task and return the task identifier. [write][write] change SunoAPI state — confirm the exact payload and effect with the user before running.[destructive] remove or overwrite data — always confirm the target and get explicit approval first.These are one-time steps — do not repeat them on every call. Run a step only when a command fails for the matching reason.
oo: command not found — install the oo CLI (other platforms: ```bash
curl -fsSL https://cli.oomol.com/install.sh | bash # macOS / Linux
```
```powershell
irm https://cli.oomol.com/install.ps1 | iex # Windows PowerShell
```
```bash
oo auth login
```
scope_missing / credential_expired / app_not_ready / app_not_found — SunoAPI is not connected, or the connection expired or lacks a scope. Connect once (auth type: API key) at:```text
https://console.oomol.com/app-connections?provider=sunoapi
```
OOMOL_INSUFFICIENT_CREDIT — billing stop. Recharge at https://console.oomol.com/billing/token-recharge before retrying.共 2 个版本