maxBytes 限制。Body 替换为 [Audio] 块并设置 {{Transcript}}。CommandBody/RawBody 会设置为转录文本,因此斜杠命令仍然有效。--verbose 模式下,我们会在转录运行和替换正文时记录日志。如果你未配置模型且 tools.media.audio.enabled 未设置为 false,OpenClaw 会按以下顺序自动检测,并在找到第一个可用选项时停止:
sherpa-onnx-offline(需要 SHERPA_ONNX_MODEL_DIR 包含 encoder/decoder/joiner/tokens)whisper-cli(来自 whisper-cpp;使用 WHISPER_CPP_MODEL 或内置的 tiny 模型)whisper(Python CLI;自动下载模型)gemini)使用 read_many_files要禁用自动检测,请设置 tools.media.audio.enabled: false。
要自定义,请设置 tools.media.audio.models。
注意:二进制检测在 macOS/Linux/Windows 上采用尽力而为的方式;请确保 CLI 在 PATH 中(我们会展开 ~),或通过完整命令路径设置显式 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" }],
},
},
},
}
{
tools: {
media: {
audio: {
enabled: true,
models: [{ provider: "deepgram", model: "nova-3" }],
},
},
},
}
models.providers.*.apiKey)。provider: "deepgram" 时,Deepgram 会读取 DEEPGRAM_API_KEY。tools.media.audio 覆盖 baseUrl、headers 和 providerOptions。tools.media.audio.maxBytes)。超大音频会跳过该模型并尝试下一个条目。maxChars 未设置(完整转录文本)。设置 tools.media.audio.maxChars 或每个条目的 maxChars 来裁剪输出。gpt-4o-mini-transcribe;设置 model: "gpt-4o-transcribe" 可获得更高准确度。tools.media.audio.attachments 处理多条语音消息(mode: "all" + maxAttachments)。{{Transcript}} 使用。chatType 会被规范化为 direct、group 或 room。jq -r .text 进行转换。timeoutSeconds,默认 60 秒),以避免阻塞回复队列。