媒体与设备
音频和语音消息
可用功能
- 媒体理解(音频):如果启用了音频理解(或自动检测到),OpenClaw 会:
- 定位第一个音频附件(本地路径或 URL),并在需要时下载它。
- 在发送到每个模型条目前强制检查
maxBytes。 - 按顺序运行第一个符合条件的模型条目(提供商或 CLI)。
- 如果失败或跳过(大小/超时),会尝试下一个条目。
- 成功后,它会将
Body替换为[Audio]块,并设置{{Transcript}}。
- 命令解析:转录成功时,
CommandBody/RawBody会被设置为转录文本,因此斜杠命令仍然可用。 - 详细日志:在
--verbose下,我们会记录转录何时运行,以及何时替换正文。
自动检测(默认)
如果你没有配置模型,并且 tools.media.audio.enabled 未设置为 false,
OpenClaw 会按以下顺序自动检测,并在第一个可用选项处停止:
- 当前回复模型,当其提供商支持音频理解时。
- 本地 CLI(如果已安装)
sherpa-onnx-offline(需要带有 encoder/decoder/joiner/tokens 的SHERPA_ONNX_MODEL_DIR)whisper-cli(来自whisper-cpp;使用WHISPER_CPP_MODEL或内置 tiny 模型)whisper(Python CLI;自动下载模型)
- Gemini CLI(
gemini),使用read_many_files - 提供商凭证
- 会优先尝试配置的、支持音频的
models.providers.*条目 - 内置备用顺序:OpenAI → Groq → xAI → Deepgram → Google → SenseAudio → ElevenLabs → Mistral
- 会优先尝试配置的、支持音频的
要禁用自动检测,请设置 tools.media.audio.enabled: false。
要自定义,请设置 tools.media.audio.models。
注意:二进制检测在 macOS/Linux/Windows 上是尽力而为;请确保 CLI 在 PATH 上(我们会展开 ~),或设置一个带完整命令路径的显式 CLI 模型。
配置示例
提供商 + CLI 备用(OpenAI + Whisper CLI)
{
tools: {
media: {
audio: {
enabled: true,
maxBytes: 20971520,
models: [
{ provider: "openai", model: "gpt-4o-mini-transcribe" },
{
type: "cli",
command: "whisper",
args: ["--model", "base", "{{MediaPath}}"],
timeoutSeconds: 45,
},
],
},
},
},
}
仅提供商并使用范围门控
{
tools: {
media: {
audio: {
enabled: true,
scope: {
default: "allow",
rules: [{ action: "deny", match: { chatType: "group" } }],
},
models: [{ provider: "openai", model: "gpt-4o-mini-transcribe" }],
},
},
},
}
仅提供商(Deepgram)
{
tools: {
media: {
audio: {
enabled: true,
models: [{ provider: "deepgram", model: "nova-3" }],
},
},
},
}
仅提供商(Mistral Voxtral)
{
tools: {
media: {
audio: {
enabled: true,
models: [{ provider: "mistral", model: "voxtral-mini-latest" }],
},
},
},
}
仅提供商(SenseAudio)
{
tools: {
media: {
audio: {
enabled: true,
models: [{ provider: "senseaudio", model: "senseaudio-asr-pro-1.5-260319" }],
},
},
},
}
将转录文本回显到聊天(选择启用)
{
tools: {
media: {
audio: {
enabled: true,
echoTranscript: true, // default is false
echoFormat: '📝 "{transcript}"', // optional, supports {transcript}
models: [{ provider: "openai", model: "gpt-4o-mini-transcribe" }],
},
},
},
}
注意事项和限制
- 提供商凭证遵循标准模型凭证顺序(凭证配置文件、环境变量、
models.providers.*.apiKey)。 - Groq 设置详情:Groq。
- 使用
provider: "deepgram"时,Deepgram 会读取DEEPGRAM_API_KEY。 - Deepgram 设置详情:Deepgram(音频转录)。
- Mistral 设置详情:Mistral。
- 使用
provider: "senseaudio"时,SenseAudio 会读取SENSEAUDIO_API_KEY。 - SenseAudio 设置详情:SenseAudio。
- 音频提供商可以通过
tools.media.audio覆盖baseUrl、headers和providerOptions。 - 默认大小上限为 20MB(
tools.media.audio.maxBytes)。超大音频会被该模型跳过,并尝试下一个条目。 - 低于 1024 字节的微小/空音频文件会在提供商/CLI 转录前被跳过。
- 音频的默认
maxChars未设置(完整转录文本)。设置tools.media.audio.maxChars或每条目的maxChars来裁剪输出。 - OpenAI 自动默认值为
gpt-4o-mini-transcribe;设置model: "gpt-4o-transcribe"可获得更高准确率。 - 使用
tools.media.audio.attachments处理多条语音消息(mode: "all"+maxAttachments)。 - 转录文本可作为
{{Transcript}}在模板中使用。 tools.media.audio.echoTranscript默认关闭;启用它可在智能体处理前,将转录确认发送回原始聊天。tools.media.audio.echoFormat用于自定义回显文本(占位符:{transcript})。- CLI stdout 有上限(5MB);请保持 CLI 输出简洁。
- CLI
args应使用{{MediaPath}}表示本地音频文件路径。运行openclaw doctor --fix,可从较旧的audio.transcription.command配置迁移已弃用的{input}占位符。
代理环境支持
基于提供商的音频转录会遵循标准出站代理环境变量:
HTTPS_PROXYHTTP_PROXYALL_PROXYhttps_proxyhttp_proxyall_proxy
如果未设置代理环境变量,则使用直接出站连接。如果代理配置格式错误,OpenClaw 会记录警告并回退到直接获取。
群组中的提及检测
当群聊设置了 requireMention: true 时,OpenClaw 现在会在检查提及之前转录音频。这样即使语音消息中包含提及,也可以被处理。
工作方式:
- 如果一条语音消息没有文本正文,并且群组要求提及,OpenClaw 会执行一次“预检”转录。
- 转录文本会被检查是否包含提及模式(例如
@BotName、emoji 触发器)。 - 如果找到提及,消息会继续进入完整回复管线。
- 转录文本用于提及检测,因此语音消息可以通过提及门控。
备用行为:
- 如果预检期间转录失败(超时、API 错误等),消息会基于纯文本提及检测进行处理。
- 这确保混合消息(文本 + 音频)绝不会被错误丢弃。
按 Telegram 群组/话题选择退出:
- 设置
channels.telegram.groups.<chatId>.disableAudioPreflight: true可跳过该群组的预检转录提及检查。 - 设置
channels.telegram.groups.<chatId>.topics.<threadId>.disableAudioPreflight可按话题覆盖(true表示跳过,false表示强制启用)。 - 默认值为
false(当提及门控条件匹配时启用预检)。
示例: 用户在设置了 requireMention: true 的 Telegram 群组中发送一条语音消息,说“Hey @Claude, what's the weather?”。语音消息会被转录,提及会被检测到,智能体随后回复。
注意点
- 范围规则采用首个匹配优先。
chatType会标准化为direct、group或room。 - 确保你的 CLI 以 0 退出并打印纯文本;JSON 需要通过
jq -r .text处理。 - 对于
parakeet-mlx,如果你传入--output-dir,当--output-format为txt(或省略)时,OpenClaw 会读取<output-dir>/<media-basename>.txt;非txt输出格式会回退到解析 stdout。 - 保持合理的超时时间(
timeoutSeconds,默认 60 秒),避免阻塞回复队列。 - 预检转录只处理用于提及检测的第一个音频附件。其他音频会在主媒体理解阶段处理。