Class: Vapi::ServerMessageSpeechUpdate
- Inherits:
-
Object
- Object
- Vapi::ServerMessageSpeechUpdate
- Defined in:
- lib/vapi_server_sdk/types/server_message_speech_update.rb
Constant Summary collapse
- OMIT =
Object.new
Instance Attribute Summary collapse
-
#additional_properties ⇒ OpenStruct
readonly
Additional properties unmapped to the current class definition.
-
#artifact ⇒ Vapi::Artifact
readonly
This is a live version of the ‘call.artifact`.
-
#assistant ⇒ Vapi::CreateAssistantDto
readonly
This is the assistant that is currently active.
-
#call ⇒ Vapi::Call
readonly
This is the call object.
-
#customer ⇒ Vapi::CreateCustomerDto
readonly
This is the customer associated with the call.
-
#phone_number ⇒ Vapi::ServerMessageSpeechUpdatePhoneNumber
readonly
This is the phone number associated with the call.
-
#role ⇒ Vapi::ServerMessageSpeechUpdateRole
readonly
This is the role which the speech update is for.
-
#status ⇒ Vapi::ServerMessageSpeechUpdateStatus
readonly
This is the status of the speech update.
-
#timestamp ⇒ String
readonly
This is the ISO-8601 formatted timestamp of when the message was sent.
Class Method Summary collapse
-
.from_json(json_object:) ⇒ Vapi::ServerMessageSpeechUpdate
Deserialize a JSON object to an instance of ServerMessageSpeechUpdate.
-
.validate_raw(obj:) ⇒ Void
Leveraged for Union-type generation, validate_raw attempts to parse the given hash and check each fields type against the current object’s property definitions.
Instance Method Summary collapse
- #initialize(status:, role:, phone_number: OMIT, timestamp: OMIT, artifact: OMIT, assistant: OMIT, customer: OMIT, call: OMIT, additional_properties: nil) ⇒ Vapi::ServerMessageSpeechUpdate constructor
-
#to_json(*_args) ⇒ String
Serialize an instance of ServerMessageSpeechUpdate to a JSON object.
Constructor Details
#initialize(status:, role:, phone_number: OMIT, timestamp: OMIT, artifact: OMIT, assistant: OMIT, customer: OMIT, call: OMIT, additional_properties: nil) ⇒ Vapi::ServerMessageSpeechUpdate
85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 85 def initialize(status:, role:, phone_number: OMIT, timestamp: OMIT, artifact: OMIT, assistant: OMIT, customer: OMIT, call: OMIT, additional_properties: nil) @phone_number = phone_number if phone_number != OMIT @status = status @role = role @timestamp = if != OMIT @artifact = artifact if artifact != OMIT @assistant = assistant if assistant != OMIT @customer = customer if customer != OMIT @call = call if call != OMIT @additional_properties = additional_properties @_field_set = { "phoneNumber": phone_number, "status": status, "role": role, "timestamp": , "artifact": artifact, "assistant": assistant, "customer": customer, "call": call }.reject do |_k, v| v == OMIT end end |
Instance Attribute Details
#additional_properties ⇒ OpenStruct (readonly)
Returns Additional properties unmapped to the current class definition.
50 51 52 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 50 def additional_properties @additional_properties end |
#artifact ⇒ Vapi::Artifact (readonly)
Returns This is a live version of the ‘call.artifact`. This matches what is stored on `call.artifact` after the call.
28 29 30 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 28 def artifact @artifact end |
#assistant ⇒ Vapi::CreateAssistantDto (readonly)
Returns This is the assistant that is currently active. This is provided for convenience. This matches one of the following:
-
‘call.assistant`,
-
‘call.assistantId`,
-
‘call.squad.assistant`,
-
‘call.squad.assistantId`,
-
‘call.squadId->.assistant`,
-
‘call.squadId->.assistantId`.
38 39 40 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 38 def assistant @assistant end |
#call ⇒ Vapi::Call (readonly)
Returns This is the call object. This matches what was returned in POST /call. Note: This might get stale during the call. To get the latest call object, especially after the call is ended, use GET /call/:id.
48 49 50 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 48 def call @call end |
#customer ⇒ Vapi::CreateCustomerDto (readonly)
Returns This is the customer associated with the call. This matches one of the following:
-
‘call.customer`,
-
‘call.customerId`.
43 44 45 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 43 def customer @customer end |
#phone_number ⇒ Vapi::ServerMessageSpeechUpdatePhoneNumber (readonly)
Returns This is the phone number associated with the call. This matches one of the following:
-
‘call.phoneNumber`,
-
‘call.phoneNumberId`.
19 20 21 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 19 def phone_number @phone_number end |
#role ⇒ Vapi::ServerMessageSpeechUpdateRole (readonly)
Returns This is the role which the speech update is for.
23 24 25 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 23 def role @role end |
#status ⇒ Vapi::ServerMessageSpeechUpdateStatus (readonly)
Returns This is the status of the speech update.
21 22 23 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 21 def status @status end |
#timestamp ⇒ String (readonly)
Returns This is the ISO-8601 formatted timestamp of when the message was sent.
25 26 27 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 25 def @timestamp end |
Class Method Details
.from_json(json_object:) ⇒ Vapi::ServerMessageSpeechUpdate
Deserialize a JSON object to an instance of ServerMessageSpeechUpdate
114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 114 def self.from_json(json_object:) struct = JSON.parse(json_object, object_class: OpenStruct) parsed_json = JSON.parse(json_object) if parsed_json["phoneNumber"].nil? phone_number = nil else phone_number = parsed_json["phoneNumber"].to_json phone_number = Vapi::ServerMessageSpeechUpdatePhoneNumber.from_json(json_object: phone_number) end status = parsed_json["status"] role = parsed_json["role"] = parsed_json["timestamp"] if parsed_json["artifact"].nil? artifact = nil else artifact = parsed_json["artifact"].to_json artifact = Vapi::Artifact.from_json(json_object: artifact) end if parsed_json["assistant"].nil? assistant = nil else assistant = parsed_json["assistant"].to_json assistant = Vapi::CreateAssistantDto.from_json(json_object: assistant) end if parsed_json["customer"].nil? customer = nil else customer = parsed_json["customer"].to_json customer = Vapi::CreateCustomerDto.from_json(json_object: customer) end if parsed_json["call"].nil? call = nil else call = parsed_json["call"].to_json call = Vapi::Call.from_json(json_object: call) end new( phone_number: phone_number, status: status, role: role, timestamp: , artifact: artifact, assistant: assistant, customer: customer, call: call, additional_properties: struct ) end |
.validate_raw(obj:) ⇒ Void
Leveraged for Union-type generation, validate_raw attempts to parse the given
hash and check each fields type against the current object's property
definitions.
176 177 178 179 180 181 182 183 184 185 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 176 def self.validate_raw(obj:) obj.phone_number.nil? || Vapi::ServerMessageSpeechUpdatePhoneNumber.validate_raw(obj: obj.phone_number) obj.status.is_a?(Vapi::ServerMessageSpeechUpdateStatus) != false || raise("Passed value for field obj.status is not the expected type, validation failed.") obj.role.is_a?(Vapi::ServerMessageSpeechUpdateRole) != false || raise("Passed value for field obj.role is not the expected type, validation failed.") obj.&.is_a?(String) != false || raise("Passed value for field obj.timestamp is not the expected type, validation failed.") obj.artifact.nil? || Vapi::Artifact.validate_raw(obj: obj.artifact) obj.assistant.nil? || Vapi::CreateAssistantDto.validate_raw(obj: obj.assistant) obj.customer.nil? || Vapi::CreateCustomerDto.validate_raw(obj: obj.customer) obj.call.nil? || Vapi::Call.validate_raw(obj: obj.call) end |
Instance Method Details
#to_json(*_args) ⇒ String
Serialize an instance of ServerMessageSpeechUpdate to a JSON object
166 167 168 |
# File 'lib/vapi_server_sdk/types/server_message_speech_update.rb', line 166 def to_json(*_args) @_field_set&.to_json end |