Voice Call(plugin)
OpenClaw 向けの音声通話を提供するプラグインです。発信通知および、着信ポリシーに基づくマルチターンの会話をサポートします。 3. アウトバウンド通知と、 インバウンドポリシーを伴うマルチターン会話をサポートします。 現在のプロバイダー:twilio(Programmable Voice + Media Streams)telnyx(Call Control v2)plivo(Voice API + XML transfer + GetInput speech)mock(dev/ネットワークなし)
- プラグインをインストール
- Gateway を再起動
plugins.entries.voice-call.config配下で設定openclaw voicecall ...またはvoice_callツールを使用
実行場所(ローカル vs リモート)
音声通話プラグインは Gateway プロセス内 で実行されます。 リモート Gateway を使用する場合は、Gateway を実行しているマシン にプラグインをインストール/設定し、その後 Gateway を再起動して読み込んでください。インストール
オプション A:npm からインストール(推奨)
オプション B:ローカルフォルダーからインストール(開発向け、コピーなし)
設定
plugins.entries.voice-call.config 配下に設定します:
- Twilio/Telnyx では 公開到達可能 な Webhook URL が必要です。
- Plivo でも 公開到達可能 な Webhook URL が必要です。
mockはローカル開発用のプロバイダーです(ネットワーク呼び出しなし)。- Telnyx では、
skipSignatureVerificationが true でない限り、telnyx.publicKey(またはTELNYX_PUBLIC_KEY)が必要です。 skipSignatureVerificationはローカルテスト専用です。- ngrok の free tier を使用する場合は、
publicUrlに正確な ngrok URL を設定してください。署名検証は常に有効です。 tunnel.allowNgrokFreeTierLoopbackBypass: trueは、tunnel.provider="ngrok"かつserve.bindがループバック(ngrok のローカルエージェント)の場合 のみ、無効な署名の Twilio Webhook を許可します。ローカル開発専用で使用してください。 ローカル開発者のみに使用します。 ローカル開発者のみに使用します。- ngrok の free tier URL は変更されたり、インタースティシャル挙動が追加されたりする場合があります。
publicUrlが変動すると Twilio の署名検証に失敗します。本番環境では、安定したドメインまたは Tailscale の funnel を推奨します。 生産のために、安定したドメインまたはテイルスケールの漏斗を好む。
Webhook のセキュリティ
Gateway の前段にプロキシやトンネルがある場合、プラグインは署名検証のために公開 URL を再構築します。以下のオプションで、どの転送ヘッダーを信頼するかを制御します。 これらのオプションは、どの転送された ヘッダが信頼されるかを制御します。webhookSecurity.allowedHosts は、転送ヘッダーからのホストを許可リストに基づいて許可します。
webhookSecurity.trustForwardingHeaders は、許可リストなしで転送ヘッダーを信頼します。
webhookSecurity.trustedProxyIPs は、リクエストのリモート IP がリストに一致する場合にのみ転送ヘッダーを信頼します。
安定した公開ホストを使用する例:
通話向け TTS
音声通話では、通話中のストリーミング音声に対してコアのmessages.tts 設定(OpenAI または ElevenLabs)を使用します。プラグイン設定配下で 同一の形状 のまま上書きすることも可能で、messages.tts とディープマージされます。 プラグインの設定では
同じ図形 でオーバーライドできます — messages.tts と深くマージできます。
- 音声通話では Edge TTS は無視されます(電話音声は PCM が必要であり、Edge の出力は信頼性が低いためです)。
- Twilio のメディアストリーミングが有効な場合はコア TTS が使用されます。それ以外の場合、通話はプロバイダーのネイティブ音声にフォールバックします。
追加例
コア TTS のみを使用(上書きなし):着信通話
インバウンドポリシーのデフォルトはdisabled です。 着信を有効にするには、以下を設定します。 着信を有効にするには、以下を設定します。
responseModelresponseSystemPromptresponseTimeoutMs
CLI
エージェントツール
ツール名:voice_call
アクション:
initiate_call(message, to?, mode?)continue_call(callId, message)speak_to_user(callId, message)end_call(callId)get_status(callId)
skills/voice-call/SKILL.md に対応する Skills ドキュメントが同梱されています。
Gateway RPC
voicecall.initiate(to?,message,mode?)voicecall.continue(callId,message)voicecall.speak(callId,message)voicecall.end(callId)voicecall.status(callId)