Skills ohyesai-music
Generate custom music tracks (vocal or instrumental) via OhYesAI asynchronously.
install
source · Clone the upstream repo
git clone https://github.com/openclaw/skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/openclaw/skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/bajie-git/ohyesai-music" ~/.claude/skills/clawdbot-skills-ohyesai-music && rm -rf "$T"
manifest:
skills/bajie-git/ohyesai-music/SKILL.mdsource content
Music Skill
通过调用 OhYesAI API,直接在 Clawdbot 中生成自定义风格的歌曲(支持纯音乐或带人声)。 注意:音乐生成耗时较长,本技能采用“提交任务 -> 轮询查询状态 -> 下载文件”的异步工作流。
Setup
- 首次安装/使用时,请前往获取 API Key: https://ohyesai.com
- 设置你的环境变量:
export OHEYSAI_API_KEY="your-api-key"
Usage
使用此技能生成音乐时,必须与用户进行多轮对话以收集必要参数。完成生成、下载后,必须将真实音频文件交付给用户。
参数说明
在调用 API 前,请确认以下参数:
(必填):用户提示词/歌曲的画面与情感描述,需与用户沟通获取。prompt
(必填):歌曲风格(如“流行”、“动漫”、“摇滚”等),需与用户沟通获取。styles
(必填):布尔值。instrumental
代表纯音乐(无歌词/无人声),true
代表有歌词的音乐,需与用户沟通获取。false
:歌曲标题。无需向用户询问,请根据其他参数自动推理生成一个合适的歌名。title
1. 提交任务 (Submit Task)
收集完参数后,使用
curl 调用 submit 接口提交任务:
curl -s --location --request POST "https://ohyesai.com/ohyesai-next/api/vio/skill/music-submit?apikey=$OHEYSAI_API_KEY" \ --header 'Content-Type: application/json' \ --data-raw '{ "title": "晚安", "prompt": "晚安风格的宁静歌曲", "styles": "动漫", "instrumental": true }'
返回值:该接口会返回一个
taskId(任务ID),请务必将其提取并保存,用于后续查询。
2. 查询任务状态 (Query Status)
使用获取到的
taskId 通过 GET 请求不断轮询查询任务状态:
curl -s --location --request GET "https://ohyesai.com/ohyesai-next/api/vio/skill/music-query?apikey=$OHEYSAI_API_KEY&taskId=你的taskId"
接口返回值有以下 3 种状态:
-> 任务还在排队或生成中,你需要 sleep 一段时间(如 10 秒)后继续重试。**音乐生成状态**: 进行中
-> 任务完成,状态文本后会附加包含 MP3 音频链接的 Markdown 文本。**音乐生成状态**: 已完成
-> 任务生成失败或 ID 错误,应终止轮询并告知用户。**任务不存在**
3. 下载与交付 (Download and Deliver)
当状态变为已完成时,返回值示例:
**音乐生成状态**: 已完成 [晚安_1](https://ohyesainext-test.tos-cn-beijing.volces.com/mv%2F202603%2F66d82e777e2544a89a6c3aedc9f60c93.mp3?...) [晚安_2](https://ohyesainext-test.tos-cn-beijing.volces.com/mv%2F202603%2F66d82e777e2544a89a6c3ae706362o75.mp3?...)
必须严格执行以下交付操作:
- 从上述返回值中提取出
文件的 URL。.mp3 - 使用
命令将音频文件下载到当前工作目录。curl -o "文件名.mp3" "音频URL" - ⚠️ 致命注意(推送文件): 下载完成后,绝对不能仅仅回复纯文本! 你必须输出可供用户点击的本地文件链接,例如
或者调用系统内置的发文件工具将本地 MP3 推送给用户。[点击下载 晚安_1.mp3](./晚安_1.mp3)
Examples
这里提供了一个标准的 Bash 自动化脚本,它整合了提交、轮询、提取、下载的全流程,你(大语言模型)可以直接修改参数并执行此脚本来完成整个任务:
# 1. 提交任务并获取 Task ID TASK_ID=$(curl -s --location --request POST "https://ohyesai.com/ohyesai-next/api/vio/skill/music-submit?apikey=$OHEYSAI_API_KEY" \ --header 'Content-Type: application/json' \ --data-raw '{ "title": "安眠曲", "prompt": "安静助眠的轻音乐", "styles": "动漫", "instrumental": true }') # 简单清理可能存在的引号或换行符 TASK_ID=$(echo "$TASK_ID" | tr -d '"' | tr -d '\n' | tr -d '\r') echo "Task Submitted! Task ID: $TASK_ID" echo "开始轮询等待音乐生成..." # 2. 轮询状态 while true; do RESULT=$(curl -s --location --request GET "https://ohyesai.com/ohyesai-next/api/vio/skill/music-query?apikey=$OHEYSAI_API_KEY&taskId=$TASK_ID") if echo "$RESULT" | grep -q "已完成"; then echo "音乐生成已完成!" # 3. 提取 MP3 URL(正则提取 http...mp3... 括号内的内容) MP3_URL=$(echo "$RESULT" | grep -o 'http[^)]*' | head -n 1) if [ -n "$MP3_URL" ]; then echo "正在下载音频..." curl -s -o "安眠曲_1.mp3" "$MP3_URL" echo "下载成功!文件已保存为 ./安眠曲_1.mp3" else echo "未能提取到有效的音频 URL" fi break elif echo "$RESULT" | grep -q "任务不存在"; then echo "查询失败:任务不存在或已失效。" break else echo "生成中,等待 20 秒后重试..." sleep 20 fi done
完整工作流说明
- 询问用户获取
,prompt
,styles
。instrumental - 自动生成
,代入上述示例脚本并执行。title - 脚本执行完毕并显示“下载成功”后,向用户回复:"您的音乐已生成完毕,请点击此处收听/下载:安眠曲_1.mp3" (或者调用系统发文件的内置能力)。
联系客服
