Class: Vapi::ServerMessageResponseTransferDestinationRequestMessage

Inherits:
Object
  • Object
show all
Defined in:
lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb

Overview

This is the message that will be spoken to the user as the tool is running.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(member:, discriminant:) ⇒ Vapi::ServerMessageResponseTransferDestinationRequestMessage

Parameters:

  • member (Object)
  • discriminant (String)


23
24
25
26
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 23

def initialize(member:, discriminant:)
  @member = member
  @discriminant = discriminant
end

Instance Attribute Details

#discriminantString (readonly)

Returns:

  • (String)


15
16
17
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 15

def discriminant
  @discriminant
end

#memberObject (readonly)

Returns:

  • (Object)


13
14
15
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 13

def member
  @member
end

Class Method Details

.from_json(json_object:) ⇒ Vapi::ServerMessageResponseTransferDestinationRequestMessage

Deserialize a JSON object to an instance of

ServerMessageResponseTransferDestinationRequestMessage

Parameters:

  • json_object (String)

Returns:



33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 33

def self.from_json(json_object:)
  struct = JSON.parse(json_object, object_class: OpenStruct)
  member = case struct.type
           when "request-start"
             Vapi::ToolMessageStart.from_json(json_object: json_object)
           when "request-complete"
             Vapi::ToolMessageComplete.from_json(json_object: json_object)
           when "request-failed"
             Vapi::ToolMessageFailed.from_json(json_object: json_object)
           when "request-response-delayed"
             Vapi::ToolMessageDelayed.from_json(json_object: json_object)
           else
             Vapi::ToolMessageStart.from_json(json_object: json_object)
           end
  new(member: member, discriminant: struct.type)
end

.request_complete(member:) ⇒ Vapi::ServerMessageResponseTransferDestinationRequestMessage



106
107
108
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 106

def self.request_complete(member:)
  new(member: member, discriminant: "request-complete")
end

.request_failed(member:) ⇒ Vapi::ServerMessageResponseTransferDestinationRequestMessage



112
113
114
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 112

def self.request_failed(member:)
  new(member: member, discriminant: "request-failed")
end

.request_response_delayed(member:) ⇒ Vapi::ServerMessageResponseTransferDestinationRequestMessage



118
119
120
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 118

def self.request_response_delayed(member:)
  new(member: member, discriminant: "request-response-delayed")
end

.request_start(member:) ⇒ Vapi::ServerMessageResponseTransferDestinationRequestMessage



100
101
102
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 100

def self.request_start(member:)
  new(member: member, discriminant: "request-start")
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.

Parameters:

  • obj (Object)

Returns:

  • (Void)


75
76
77
78
79
80
81
82
83
84
85
86
87
88
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 75

def self.validate_raw(obj:)
  case obj.type
  when "request-start"
    Vapi::ToolMessageStart.validate_raw(obj: obj)
  when "request-complete"
    Vapi::ToolMessageComplete.validate_raw(obj: obj)
  when "request-failed"
    Vapi::ToolMessageFailed.validate_raw(obj: obj)
  when "request-response-delayed"
    Vapi::ToolMessageDelayed.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.

Parameters:

  • obj (Object)

Returns:

  • (Boolean)


94
95
96
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 94

def is_a?(obj)
  @member.is_a?(obj)
end

#kind_of?Object



18
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 18

alias kind_of? is_a?

#to_json(*_args) ⇒ String

For Union Types, to_json functionality is delegated to the wrapped member.

Returns:

  • (String)


53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
# File 'lib/vapi_server_sdk/types/server_message_response_transfer_destination_request_message.rb', line 53

def to_json(*_args)
  case @discriminant
  when "request-start"
    { **@member.to_json, type: @discriminant }.to_json
  when "request-complete"
    { **@member.to_json, type: @discriminant }.to_json
  when "request-failed"
    { **@member.to_json, type: @discriminant }.to_json
  when "request-response-delayed"
    { **@member.to_json, type: @discriminant }.to_json
  else
    { "type": @discriminant, value: @member }.to_json
  end
  @member.to_json
end