Install
openclaw skills install audiobooklm-podcast基于新音剪创作平台以及珠峰AI自研音色,提供播客创作、内容管理、音频生成、专辑上架等功能。适用于用户提出"播客生成"、"播客制作"等需求。
openclaw skills install audiobooklm-podcastaudiobooklm_mcp 的标准播客/有声书生产链路。用户提供文本(或让用户先生成),最终产出可上架的章节音频。
调用任意 mcp__audiobooklm_mcp__* 工具时,如果返回 401/403/unauthorized/token expired/connection refused 等错误,暂停业务流程并提示用户配置 MCP。
配置指引:
看起来你还没接入
audiobooklm_mcp,按以下 4 步完成配置:
- 注册/登录 https://aigc.ximalaya.com/user
- 创建制作组,生成 API Token
- 把 MCP 服务写入配置:
{ "mcpServers": { "audiobooklm_mcp": { "type": "http", "url": "https://aigc.ximalaya.com/audiobooklm/mcp", "headers": { "Authorization": "Bearer <Token>" } } } }
- 重启服务,确认mcp已连接成功(需要结合当前环境给出具体的重启提示)
开始前必须确认以下信息:
| 字段 | 是否必需 | 处理方式 |
|---|---|---|
| 文本内容 | 必需 | 用户已给直接用;让你生成则先出文案确认 |
| 书籍 | 必需 | 询问:新建还是用已有? |
| 章节名 | 必需 | 询问用户确认 |
| 文本形态 | 必需 | 普通旁白/单人播客 vs 多人对话(决定导入工具) |
| 音色 | 必需 | 调用 list_tts_voices 向用户展示候选 |
| 专辑 | 可选 | 仅上架时需要,询问:新建/已有/不上架 |
询问用户:新建书籍还是用已有书籍?
新建 → 向用户确认书名后调用:
book_create(book_name="<书名>", book_type="podcast")
已有 → 用 read_abs(scope={"domain":"books"}) 拉取书架,列出最近 10 本让用户选择
根据文本形态选择工具:
普通旁白/单人播客 → podcast_import
podcast_import(
book_id=<book_id>,
chapter_name="<章节名>", # 新建章节时必填
script_lines=["文本1", "文本2", ...], # 单人播客只需要传入文本列表,不需要角色标识
)
多人对话 → podcast_import
podcast_import(
book_id=<book_id>,
chapter_name="<章节名>", # 新建章节时必填
script_lines=["[角色名] 文本1", "[角色名] 文本2", ...] # 多人播客需要给出每段文本的角色名
)
注意:
[角色名] 文本文本调用 list_tts_voices() 获取音色列表。
筛选建议:
询问用户:每个角色分别选哪个音色?
mcp__audiobooklm_mcp__patch_abs(
scope={"domain": "book", "book_id": <book_id>},
operations=[
{
"op_id": "op-<角色序号>",
"type": "update_character",
"character_id": <character_id>,
"patch": {"speaker_id": <speaker_id>},
"reason": "绑定音色"
}
// 多个角色用逗号分隔
]
)
⚠️ 注意:
使用 chapter_task_create 一次提交整章:
mcp__audiobooklm_mcp__chapter_task_create(
book_id=<book_id>,
chapter_id=<chapter_id>
)
返回 task_ids 列表。
mcp__audiobooklm_mcp__task_query(
task_ids=[<task_ids列表>],
wait_timeout=120 # 可根据段落数调整
)
所有段落 status=succeeded 后继续。
mcp__audiobooklm_mcp__chapter_audio_mix(
book_id=<book_id>,
chapter_id=<chapter_id>
)
⚠️ 顺序要求:必须先完成第 7 步,再调用混音。
返回 audio_url 即章节完整音频。
询问用户:需要上架到专辑吗?新建/已有/不上架?
新建专辑 → 询问专辑名后调用:
mcp__audiobooklm_mcp__create_album(
album_name="<专辑名>",
book_content="<简介>" # 可选,让 AI 生成封面
)
已有专辑 → 用户提供 album_id
上架:
mcp__audiobooklm_mcp__upload_audio_to_album(
album_id=<album_id>,
audio_url=<第8步返回的audio_url>
)
完成后告诉用户:
| 现象 | 原因 | 解决 |
|---|---|---|
找不到 mcp__audiobooklm_mcp__* | MCP 未注册 | 配置 MCP |
| 401/403/unauthorized | Token 无效/过期 | 重新生成 Token |
| patch_abs validation_failed | 缺 op_id 或 type | 检查 operation 格式 |
| task_query 返回 processing | 异步任务未完成 | 继续轮询 task_query |
| 音色不对 | character 未绑定 speaker | 重新绑定步骤 |
| create_album 失败 | 需要 book_content | 传入简介文本 |
适用于用户已提供:book_id + 章节名 + 对话脚本(格式为 [角色名] 文本)
podcast_import 导入章节 → 获得 chapter_id 和 characterslist_tts_voices 列出音色 → 用户为每个角色选择patch_abs 绑定音色 → 每个角色都要绑chapter_task_create 提交整章task_query 查询结果chapter_audio_mix 混音