Class: Vellum::ChatMessageContent
- Inherits:
-
Object
- Object
- Vellum::ChatMessageContent
- Defined in:
- lib/vellum_ai/types/chat_message_content.rb
Instance Attribute Summary collapse
-
#discriminant ⇒ Object
readonly
Returns the value of attribute discriminant.
-
#member ⇒ Object
readonly
Returns the value of attribute member.
Class Method Summary collapse
- .array(member:) ⇒ ChatMessageContent
-
.from_json(json_object:) ⇒ ChatMessageContent
Deserialize a JSON object to an instance of ChatMessageContent.
- .function_call(member:) ⇒ ChatMessageContent
- .image(member:) ⇒ ChatMessageContent
- .string(member:) ⇒ ChatMessageContent
-
.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:) ⇒ ChatMessageContent constructor
-
#is_a?(obj) ⇒ Boolean
For Union Types, is_a? functionality is delegated to the wrapped member.
- #kind_of? ⇒ Object
-
#to_json(*_args) ⇒ JSON
For Union Types, to_json functionality is delegated to the wrapped member.
Constructor Details
#initialize(member:, discriminant:) ⇒ ChatMessageContent
18 19 20 21 22 23 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 18 def initialize(member:, discriminant:) # @type [Object] @member = member # @type [String] @discriminant = discriminant end |
Instance Attribute Details
#discriminant ⇒ Object (readonly)
Returns the value of attribute discriminant.
11 12 13 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 11 def discriminant @discriminant end |
#member ⇒ Object (readonly)
Returns the value of attribute member.
11 12 13 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 11 def member @member end |
Class Method Details
.array(member:) ⇒ ChatMessageContent
106 107 108 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 106 def self.array(member:) new(member: member, discriminant: "ARRAY") end |
.from_json(json_object:) ⇒ ChatMessageContent
Deserialize a JSON object to an instance of ChatMessageContent
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 29 def self.from_json(json_object:) struct = JSON.parse(json_object, object_class: OpenStruct) member = case struct.type when "STRING" StringChatMessageContent.from_json(json_object: json_object) when "FUNCTION_CALL" FunctionCallChatMessageContent.from_json(json_object: json_object) when "ARRAY" ArrayChatMessageContent.from_json(json_object: json_object) when "IMAGE" ImageChatMessageContent.from_json(json_object: json_object) else StringChatMessageContent.from_json(json_object: json_object) end new(member: member, discriminant: struct.type) end |
.function_call(member:) ⇒ ChatMessageContent
100 101 102 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 100 def self.function_call(member:) new(member: member, discriminant: "FUNCTION_CALL") end |
.image(member:) ⇒ ChatMessageContent
112 113 114 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 112 def self.image(member:) new(member: member, discriminant: "IMAGE") end |
.string(member:) ⇒ ChatMessageContent
94 95 96 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 94 def self.string(member:) new(member: member, discriminant: "STRING") 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.
69 70 71 72 73 74 75 76 77 78 79 80 81 82 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 69 def self.validate_raw(obj:) case obj.type when "STRING" StringChatMessageContent.validate_raw(obj: obj) when "FUNCTION_CALL" FunctionCallChatMessageContent.validate_raw(obj: obj) when "ARRAY" ArrayChatMessageContent.validate_raw(obj: obj) when "IMAGE" ImageChatMessageContent.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.
88 89 90 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 88 def is_a?(obj) @member.is_a?(obj) end |
#kind_of? ⇒ Object
14 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 14 alias kind_of? is_a? |
#to_json(*_args) ⇒ JSON
For Union Types, to_json functionality is delegated to the wrapped member.
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
# File 'lib/vellum_ai/types/chat_message_content.rb', line 49 def to_json(*_args) case @discriminant when "STRING" { **@member.to_json, type: @discriminant }.to_json when "FUNCTION_CALL" { **@member.to_json, type: @discriminant }.to_json when "ARRAY" { **@member.to_json, type: @discriminant }.to_json when "IMAGE" { **@member.to_json, type: @discriminant }.to_json else { "type": @discriminant, value: @member }.to_json end @member.to_json end |