_ROOT="$(git rev-parse --show-toplevel 2>/dev/null || pwd)"
[ -x "$_ROOT/skill/bin/baiyin-skill-update-check" ] && _UPD=$(bash "$_ROOT/skill/bin/baiyin-skill-update-check" "$_ROOT/skill/baiyin-digital-human-lipsync" 2>/dev/null || true)
[ -n "${_UPD:-}" ] && echo "$_UPD"
如果输出 UPGRADE_AVAILABLE :
skill/baiyin-skills-upgrade/SKILL.md,执行其中的「内联升级流程」。AskUserQuestion,使用中文四选一:立即更新 / 以后自动更新 / 暂不更新 / 不再提醒。AskUserQuestion(例如 OpenClaw 当前会话),直接询问用户: 检测到百音技能
如果输出 JUST_UPGRADED :
百音技能 已更新到 v,继续处理你的请求。 如果输出 UP_TO_DATE、SNOOZED、CHECK_DISABLED 或 CHECK_FAILED:
当用户希望通过百音开放平台创建 AI 数字人视频任务、查询任务进度,或获取最终视频结果时,使用这个 skill。
BAIYIN_API_KEYBASE_URL 固定使用 https://ai.hikoon.com
BAIYIN_API_KEY 缺失时,才向用户索要 API Key。POST {BASE_URL}/api/open/v1/file/upload
Authorization: Bearer ,Content-Type: multipart/form-data
file 必填,filename 选填,dir 选填
data.url 取公网地址,填入 params.audio、params.first_frame 等需要 URL 的字段
GET {BASE_URL}/api/open/v1/models?modelType=adls&status=1
POST {BASE_URL}/api/open/v1/digital-human/create
GET {BASE_URL}/api/open/v1/tasks/{taskId}
根据用户表达判断当前模式,不要让用户去选技术字段名。
params.audio、params.first_frame
taskId,或用户消息里直接提供的 taskId
创建任务前,必须先调用模型列表接口获取当前可用的数字人模型,不允许使用固定写死的模型列表。
GET {BASE_URL}/api/open/v1/models?modelType=adls&status=1
返回示例:
{
"code": 200,
"data": {
"rows": [
{
"modelCode": "std",
"modelName": "可灵数字人(对口型)",
"desc": "...",
"generalNotes": "..."
},
{
"modelCode": "jimeng_realman_avatar_picture_omni_v15",
"modelName": "即梦数字人(对口型、驱动肢体)",
"desc": "...",
"generalNotes": "..."
}
],
"count": 2
}
}
data.rows 作为可选数字人模型列表
modelName,不展示 modelCode、desc 和 generalNotes
modelCode 作为请求参数传入
modelName 做模糊匹配,自动映射到对应 modelCode,不需要再次让用户选择
modelName 文字传给后端,只传 modelCode
modelCode 前,不要继续进入参数收集步骤
modelCode(从模型选项映射)
params.audio(必填)
params.first_frame(必填)
params.resolution(可选)
count(可选)
prompt(可选)
modelCode
data.rows 中取值,不接受接口返回以外的值。
params.first_frame
params.audio
params.resolution
"1080"。
count
prompt
最小请求(必填字段):
{
"modelCode": "std",
"params": {
"first_frame": "https://example.com/avatar.jpg",
"audio": "https://example.com/audio.mp3"
}
}
完整请求示例:
{
"modelCode": "jimeng_realman_avatar_picture_omni_v15",
"params": {
"resolution": "1080",
"first_frame": "https://example.com/avatar.jpg",
"audio": "https://example.com/audio.mp3"
},
"count": 1,
"prompt": "跳舞"
}
prompt 等文本字段时,必须确保请求体使用 UTF-8 编码。
??、乱码、替代字符当作有效内容。
查询接口会返回标准化状态,以及以下字段:
taskId
requestId
capability
status
result(包含视频链接等结果数据)
error
可能状态:
queued
processing
succeeded
failed
params.audio、params.first_frame,缺少的逐一追问。
taskId。
taskId,但用户要查状态或结果,就直接让用户提供 taskId。
用户说以下关键词时,可以与模型列表接口返回的 modelName 做模糊匹配,自动映射到对应 modelCode,不需要再次展示选项:
modelName 包含该关键词的模型
modelCode
只有在以下情况下才追问:
params.audio(参考音频 URL)
params.first_frame(首帧图片 URL)
taskId
不要为了确认以下内容单独追问:
params.resolution
count
prompt
a. 如果用户未指定模型,先调用 GET {BASE_URL}/api/open/v1/models?modelType=adls&status=1 获取可用模型列表,展示给用户选择。
b. 如果模型列表接口调用失败或返回为空,告知用户无法获取模型列表,不要使用固定数据继续。
c. 确认 params.audio、params.first_frame 均已提供,缺少的追问。
d. 组装请求体,params 下只传用户明确提供的字段。
e. 调用创建任务接口。
taskId、requestId 和当前 status。
taskId 调用任务查询接口。
error,不要假装结果已生成。
taskId
status
400 时,说明请求参数不合法或不完整,并让用户修正相关字段。
401 时,说明百音开放平台 API Key 无效或当前环境不可用。
402 时,说明账户余额不足。
404 时,说明任务不存在,并让用户提供正确的 taskId。
failed 时,有后端错误信息就直接返回。
示例 1:
帮我生成一个数字人视频
GET {BASE_URL}/api/open/v1/models?modelType=adls&status=1 获取可用模型列表
modelCode
示例 2:
用即梦数字人,音频 https://example.com/audio.mp3,首帧 https://example.com/avatar.jpg
modelCode
params.audio = "https://example.com/audio.mp3"
params.first_frame = "https://example.com/avatar.jpg"
示例 3:
查一下刚才那个数字人任务
taskId
示例 4:
给我 task_abc123 的结果
GET /api/open/v1/tasks/task_abc123
succeeded 时返回视频链接
succeeded 之前,不要声称视频已经完成。
queued 或 processing,就如实返回,不要虚构视频结果。
??,必须明确标记为异常结果,不能当作正常成功结果交付。
共 5 个版本