Class: Telnyx::Lib::WebSocket::SttServerEvent
- Inherits:
-
Object
- Object
- Telnyx::Lib::WebSocket::SttServerEvent
- Defined in:
- lib/telnyx/lib/websocket/stt_server_event.rb
Overview
Server event types for Speech-to-Text WebSocket streaming.
These events are received from the Telnyx STT WebSocket API during real-time audio transcription.
Example usage:
ws.on(:transcript) do |event|
puts "Transcript: #{event.transcript}" if event.is_final
end
ws.on(:error) do |event|
puts "Error: #{event.error}"
end
Instance Attribute Summary collapse
-
#confidence ⇒ Float?
Confidence score (0.0 to 1.0).
-
#duration ⇒ Float?
Duration in seconds.
-
#error ⇒ String?
Error message if type is “error”.
-
#is_final ⇒ Boolean?
Whether this is a final transcript.
-
#language ⇒ String?
Detected language code.
-
#raw ⇒ Hash?
Original raw event data.
-
#speaker ⇒ String?
Speaker identifier for diarization.
-
#start ⇒ Float?
Start time offset in seconds.
-
#transcript ⇒ String?
The transcribed text.
-
#type ⇒ String
The event type (“transcript” or “error”).
-
#words ⇒ Array<Hash>?
Word-level timing information.
Class Method Summary collapse
-
.from_hash(data) ⇒ SttServerEvent
Create an SttServerEvent from a parsed JSON hash.
Instance Method Summary collapse
-
#error? ⇒ Boolean
Check if this is an error event.
-
#final? ⇒ Boolean
Check if this is a final transcript.
Instance Attribute Details
#confidence ⇒ Float?
Returns Confidence score (0.0 to 1.0).
32 33 34 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 32 def confidence @confidence end |
#duration ⇒ Float?
Returns Duration in seconds.
41 42 43 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 41 def duration @duration end |
#error ⇒ String?
Returns Error message if type is “error”.
35 36 37 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 35 def error @error end |
#is_final ⇒ Boolean?
Returns Whether this is a final transcript.
29 30 31 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 29 def is_final @is_final end |
#language ⇒ String?
Returns Detected language code.
47 48 49 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 47 def language @language end |
#raw ⇒ Hash?
Returns Original raw event data.
53 54 55 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 53 def raw @raw end |
#speaker ⇒ String?
Returns Speaker identifier for diarization.
50 51 52 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 50 def speaker @speaker end |
#start ⇒ Float?
Returns Start time offset in seconds.
38 39 40 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 38 def start @start end |
#transcript ⇒ String?
Returns The transcribed text.
26 27 28 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 26 def transcript @transcript end |
#type ⇒ String
Returns The event type (“transcript” or “error”).
23 24 25 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 23 def type @type end |
#words ⇒ Array<Hash>?
Returns Word-level timing information.
44 45 46 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 44 def words @words end |
Class Method Details
.from_hash(data) ⇒ SttServerEvent
Create an SttServerEvent from a parsed JSON hash
59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 59 def self.from_hash(data) event = new event.raw = data event.type = data["type"] event.transcript = data["transcript"] event.is_final = data["is_final"] event.confidence = data["confidence"] event.error = data["error"] event.start = data["start"] event.duration = data["duration"] event.words = data["words"] event.language = data["language"] event.speaker = data["speaker"] event end |
Instance Method Details
#error? ⇒ Boolean
Check if this is an error event
85 86 87 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 85 def error? type == "error" end |
#final? ⇒ Boolean
Check if this is a final transcript
78 79 80 |
# File 'lib/telnyx/lib/websocket/stt_server_event.rb', line 78 def final? is_final == true end |