Class: Vapi::CallDestination

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

Overview

This is the destination where the call ended up being transferred to. If the

call was not transferred, this will be empty.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

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

Parameters:

  • member (Object)
  • discriminant (String)


22
23
24
25
# File 'lib/vapi_server_sdk/types/call_destination.rb', line 22

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

Instance Attribute Details

#discriminantString (readonly)

Returns:

  • (String)


14
15
16
# File 'lib/vapi_server_sdk/types/call_destination.rb', line 14

def discriminant
  @discriminant
end

#memberObject (readonly)

Returns:

  • (Object)


12
13
14
# File 'lib/vapi_server_sdk/types/call_destination.rb', line 12

def member
  @member
end

Class Method Details

.from_json(json_object:) ⇒ Vapi::CallDestination

Deserialize a JSON object to an instance of CallDestination

Parameters:

  • json_object (String)

Returns:



31
32
33
34
35
36
37
38
39
40
41
42
# File 'lib/vapi_server_sdk/types/call_destination.rb', line 31

def self.from_json(json_object:)
  struct = JSON.parse(json_object, object_class: OpenStruct)
  member = case struct.type
           when "number"
             Vapi::TransferDestinationNumber.from_json(json_object: json_object)
           when "sip"
             Vapi::TransferDestinationSip.from_json(json_object: json_object)
           else
             Vapi::TransferDestinationNumber.from_json(json_object: json_object)
           end
  new(member: member, discriminant: struct.type)
end

.number(member:) ⇒ Vapi::CallDestination

Parameters:

Returns:



86
87
88
# File 'lib/vapi_server_sdk/types/call_destination.rb', line 86

def self.number(member:)
  new(member: member, discriminant: "number")
end

.sip(member:) ⇒ Vapi::CallDestination

Parameters:

Returns:



92
93
94
# File 'lib/vapi_server_sdk/types/call_destination.rb', line 92

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


65
66
67
68
69
70
71
72
73
74
# File 'lib/vapi_server_sdk/types/call_destination.rb', line 65

def self.validate_raw(obj:)
  case obj.type
  when "number"
    Vapi::TransferDestinationNumber.validate_raw(obj: obj)
  when "sip"
    Vapi::TransferDestinationSip.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)


80
81
82
# File 'lib/vapi_server_sdk/types/call_destination.rb', line 80

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

#kind_of?Object



17
# File 'lib/vapi_server_sdk/types/call_destination.rb', line 17

alias kind_of? is_a?

#to_json(*_args) ⇒ String

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

Returns:

  • (String)


47
48
49
50
51
52
53
54
55
56
57
# File 'lib/vapi_server_sdk/types/call_destination.rb', line 47

def to_json(*_args)
  case @discriminant
  when "number"
    { **@member.to_json, type: @discriminant }.to_json
  when "sip"
    { **@member.to_json, type: @discriminant }.to_json
  else
    { "type": @discriminant, value: @member }.to_json
  end
  @member.to_json
end