Class: Vapi::ServerMessageToolCalls
- Inherits:
-
Object
- Object
- Vapi::ServerMessageToolCalls
- Defined in:
- lib/vapi_server_sdk/types/server_message_tool_calls.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::ServerMessageToolCallsPhoneNumber
readonly
This is the phone number associated with the call.
-
#timestamp ⇒ String
readonly
This is the ISO-8601 formatted timestamp of when the message was sent.
-
#tool_call_list ⇒ Array<Vapi::ToolCall>
readonly
This is the list of tool calls that the model is requesting.
-
#tool_with_tool_call_list ⇒ Array<Vapi::ServerMessageToolCallsToolWithToolCallListItem>
readonly
This is the list of tools calls that the model is requesting along with the original tool configuration.
Class Method Summary collapse
-
.from_json(json_object:) ⇒ Vapi::ServerMessageToolCalls
Deserialize a JSON object to an instance of ServerMessageToolCalls.
-
.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(tool_with_tool_call_list:, tool_call_list:, phone_number: OMIT, timestamp: OMIT, artifact: OMIT, assistant: OMIT, customer: OMIT, call: OMIT, additional_properties: nil) ⇒ Vapi::ServerMessageToolCalls constructor
-
#to_json(*_args) ⇒ String
Serialize an instance of ServerMessageToolCalls to a JSON object.
Constructor Details
#initialize(tool_with_tool_call_list:, tool_call_list:, phone_number: OMIT, timestamp: OMIT, artifact: OMIT, assistant: OMIT, customer: OMIT, call: OMIT, additional_properties: nil) ⇒ Vapi::ServerMessageToolCalls
87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 87 def initialize(tool_with_tool_call_list:, tool_call_list:, phone_number: OMIT, timestamp: OMIT, artifact: OMIT, assistant: OMIT, customer: OMIT, call: OMIT, additional_properties: nil) @phone_number = phone_number if phone_number != OMIT @tool_with_tool_call_list = tool_with_tool_call_list @timestamp = if != OMIT @artifact = artifact if artifact != OMIT @assistant = assistant if assistant != OMIT @customer = customer if customer != OMIT @call = call if call != OMIT @tool_call_list = tool_call_list @additional_properties = additional_properties @_field_set = { "phoneNumber": phone_number, "toolWithToolCallList": tool_with_tool_call_list, "timestamp": , "artifact": artifact, "assistant": assistant, "customer": customer, "call": call, "toolCallList": tool_call_list }.reject do |_k, v| v == OMIT end end |
Instance Attribute Details
#additional_properties ⇒ OpenStruct (readonly)
Returns Additional properties unmapped to the current class definition.
51 52 53 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 51 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.
27 28 29 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 27 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`.
37 38 39 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 37 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.
47 48 49 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 47 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`.
42 43 44 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 42 def customer @customer end |
#phone_number ⇒ Vapi::ServerMessageToolCallsPhoneNumber (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_tool_calls.rb', line 19 def phone_number @phone_number end |
#timestamp ⇒ String (readonly)
Returns This is the ISO-8601 formatted timestamp of when the message was sent.
24 25 26 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 24 def @timestamp end |
#tool_call_list ⇒ Array<Vapi::ToolCall> (readonly)
Returns This is the list of tool calls that the model is requesting.
49 50 51 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 49 def tool_call_list @tool_call_list end |
#tool_with_tool_call_list ⇒ Array<Vapi::ServerMessageToolCallsToolWithToolCallListItem> (readonly)
Returns This is the list of tools calls that the model is requesting along with the original tool configuration.
22 23 24 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 22 def tool_with_tool_call_list @tool_with_tool_call_list end |
Class Method Details
.from_json(json_object:) ⇒ Vapi::ServerMessageToolCalls
Deserialize a JSON object to an instance of ServerMessageToolCalls
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 162 163 164 165 166 167 168 169 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 116 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::ServerMessageToolCallsPhoneNumber.from_json(json_object: phone_number) end tool_with_tool_call_list = parsed_json["toolWithToolCallList"]&.map do |item| item = item.to_json Vapi::ServerMessageToolCallsToolWithToolCallListItem.from_json(json_object: item) end = 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 tool_call_list = parsed_json["toolCallList"]&.map do |item| item = item.to_json Vapi::ToolCall.from_json(json_object: item) end new( phone_number: phone_number, tool_with_tool_call_list: tool_with_tool_call_list, timestamp: , artifact: artifact, assistant: assistant, customer: customer, call: call, tool_call_list: tool_call_list, 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.
184 185 186 187 188 189 190 191 192 193 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 184 def self.validate_raw(obj:) obj.phone_number.nil? || Vapi::ServerMessageToolCallsPhoneNumber.validate_raw(obj: obj.phone_number) obj.tool_with_tool_call_list.is_a?(Array) != false || raise("Passed value for field obj.tool_with_tool_call_list 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) obj.tool_call_list.is_a?(Array) != false || raise("Passed value for field obj.tool_call_list is not the expected type, validation failed.") end |
Instance Method Details
#to_json(*_args) ⇒ String
Serialize an instance of ServerMessageToolCalls to a JSON object
174 175 176 |
# File 'lib/vapi_server_sdk/types/server_message_tool_calls.rb', line 174 def to_json(*_args) @_field_set&.to_json end |