api/ruby/telnyx-voice-gather-ruby/SKILL.md
Collect DTMF input and speech from callers using standard gather or AI-powered gather. Build interactive voice menus and AI voice assistants. This skill provides Ruby SDK examples.
npx skillsauth add team-telnyx/telnyx-toolkit telnyx-voice-gather-rubyInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
gem install telnyx
require "telnyx"
client = Telnyx::Client.new(
api_key: ENV["TELNYX_API_KEY"], # This is the default and can be omitted
)
All examples below assume client is already initialized as shown above.
Add messages to the conversation started by an AI assistant on the call.
POST /calls/{call_control_id}/actions/ai_assistant_add_messages
response = client.calls.actions.add_ai_assistant_messages("call_control_id")
puts(response)
Start an AI assistant on the call.
POST /calls/{call_control_id}/actions/ai_assistant_start
response = client.calls.actions.start_ai_assistant("call_control_id")
puts(response)
Stop an AI assistant on the call.
POST /calls/{call_control_id}/actions/ai_assistant_stop
response = client.calls.actions.stop_ai_assistant("call_control_id")
puts(response)
Stop current gather.
POST /calls/{call_control_id}/actions/gather_stop
response = client.calls.actions.stop_gather("call_control_id")
puts(response)
Gather parameters defined in the request payload using a voice assistant.
POST /calls/{call_control_id}/actions/gather_using_ai — Required: parameters
response = client.calls.actions.gather_using_ai(
"call_control_id",
parameters: {properties: "bar", required: "bar", type: "bar"}
)
puts(response)
Play an audio file on the call until the required DTMF signals are gathered to build interactive menus.
POST /calls/{call_control_id}/actions/gather_using_audio
response = client.calls.actions.gather_using_audio("call_control_id")
puts(response)
Convert text to speech and play it on the call until the required DTMF signals are gathered to build interactive menus.
POST /calls/{call_control_id}/actions/gather_using_speak — Required: voice, payload
response = client.calls.actions.gather_using_speak("call_control_id", payload: "say this on call", voice: "male")
puts(response)
Gather DTMF signals to build interactive menus.
POST /calls/{call_control_id}/actions/gather
response = client.calls.actions.gather("call_control_id")
puts(response)
The following webhook events are sent to your configured webhook URL.
All webhooks include telnyx-timestamp and telnyx-signature-ed25519 headers for verification (Standard Webhooks compatible).
| Event | Description |
|-------|-------------|
| callGatherEnded | Call Gather Ended |
| CallAIGatherEnded | Call AI Gather Ended |
| CallAIGatherMessageHistoryUpdated | Call AI Gather Message History Updated |
| CallAIGatherPartialResults | Call AI Gather Partial Results |
| CallConversationEnded | Call Conversation Ended |
| callPlaybackStarted | Call Playback Started |
| callPlaybackEnded | Call Playback Ended |
| callDtmfReceived | Call Dtmf Received |
tools
Build cross-platform VoIP calling apps with React Native using Telnyx Voice SDK. High-level reactive API with automatic lifecycle management, CallKit/ConnectionService integration, and push notifications. Use for mobile VoIP apps with minimal setup.
tools
Build browser-based VoIP calling apps using Telnyx WebRTC JavaScript SDK. Covers authentication, voice calls, events, debugging, call quality metrics, and AI Agent integration. Use for web-based real-time communication.
tools
Build VoIP calling apps on iOS using Telnyx WebRTC SDK. Covers authentication, making/receiving calls, CallKit integration, PushKit/APNS push notifications, call quality metrics, and AI Agent integration. Use when implementing real-time voice communication on iOS.
tools
Build cross-platform VoIP calling apps with Flutter using Telnyx WebRTC SDK. Covers authentication, making/receiving calls, push notifications (FCM + APNS), call quality metrics, and AI Agent integration. Works on Android, iOS, and Web.