Class: Vapi::ToolCallBlockMessagesItem
- Inherits:
-
Object
- Object
- Vapi::ToolCallBlockMessagesItem
- Defined in:
- lib/vapi_server_sdk/types/tool_call_block_messages_item.rb
Instance Attribute Summary collapse
- #discriminant ⇒ String readonly
- #member ⇒ Object readonly
Class Method Summary collapse
- .block_complete(member:) ⇒ Vapi::ToolCallBlockMessagesItem
- .block_start(member:) ⇒ Vapi::ToolCallBlockMessagesItem
-
.from_json(json_object:) ⇒ Vapi::ToolCallBlockMessagesItem
Deserialize a JSON object to an instance of ToolCallBlockMessagesItem.
-
.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(member:, discriminant:) ⇒ Vapi::ToolCallBlockMessagesItem constructor
-
#is_a?(obj) ⇒ Boolean
For Union Types, is_a? functionality is delegated to the wrapped member.
- #kind_of? ⇒ Object
-
#to_json(*_args) ⇒ String
For Union Types, to_json functionality is delegated to the wrapped member.
Constructor Details
#initialize(member:, discriminant:) ⇒ Vapi::ToolCallBlockMessagesItem
20 21 22 23 |
# File 'lib/vapi_server_sdk/types/tool_call_block_messages_item.rb', line 20 def initialize(member:, discriminant:) @member = member @discriminant = discriminant end |
Instance Attribute Details
#discriminant ⇒ String (readonly)
12 13 14 |
# File 'lib/vapi_server_sdk/types/tool_call_block_messages_item.rb', line 12 def discriminant @discriminant end |
#member ⇒ Object (readonly)
10 11 12 |
# File 'lib/vapi_server_sdk/types/tool_call_block_messages_item.rb', line 10 def member @member end |
Class Method Details
.block_complete(member:) ⇒ Vapi::ToolCallBlockMessagesItem
90 91 92 |
# File 'lib/vapi_server_sdk/types/tool_call_block_messages_item.rb', line 90 def self.block_complete(member:) new(member: member, discriminant: "block-complete") end |
.block_start(member:) ⇒ Vapi::ToolCallBlockMessagesItem
84 85 86 |
# File 'lib/vapi_server_sdk/types/tool_call_block_messages_item.rb', line 84 def self.block_start(member:) new(member: member, discriminant: "block-start") end |
.from_json(json_object:) ⇒ Vapi::ToolCallBlockMessagesItem
Deserialize a JSON object to an instance of ToolCallBlockMessagesItem
29 30 31 32 33 34 35 36 37 38 39 40 |
# File 'lib/vapi_server_sdk/types/tool_call_block_messages_item.rb', line 29 def self.from_json(json_object:) struct = JSON.parse(json_object, object_class: OpenStruct) member = case struct.type when "block-start" Vapi::BlockStartMessage.from_json(json_object: json_object) when "block-complete" Vapi::BlockCompleteMessage.from_json(json_object: json_object) else Vapi::BlockStartMessage.from_json(json_object: json_object) end new(member: member, discriminant: struct.type) 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.
63 64 65 66 67 68 69 70 71 72 |
# File 'lib/vapi_server_sdk/types/tool_call_block_messages_item.rb', line 63 def self.validate_raw(obj:) case obj.type when "block-start" Vapi::BlockStartMessage.validate_raw(obj: obj) when "block-complete" Vapi::BlockCompleteMessage.validate_raw(obj: obj) else raise("Passed value matched no type within the union, validation failed.") end end |
Instance Method Details
#is_a?(obj) ⇒ Boolean
For Union Types, is_a? functionality is delegated to the wrapped member.
78 79 80 |
# File 'lib/vapi_server_sdk/types/tool_call_block_messages_item.rb', line 78 def is_a?(obj) @member.is_a?(obj) end |
#kind_of? ⇒ Object
15 |
# File 'lib/vapi_server_sdk/types/tool_call_block_messages_item.rb', line 15 alias kind_of? is_a? |
#to_json(*_args) ⇒ String
For Union Types, to_json functionality is delegated to the wrapped member.
45 46 47 48 49 50 51 52 53 54 55 |
# File 'lib/vapi_server_sdk/types/tool_call_block_messages_item.rb', line 45 def to_json(*_args) case @discriminant when "block-start" { **@member.to_json, type: @discriminant }.to_json when "block-complete" { **@member.to_json, type: @discriminant }.to_json else { "type": @discriminant, value: @member }.to_json end @member.to_json end |