Class: Vapi::UserMessage
- Inherits:
-
Object
- Object
- Vapi::UserMessage
- Defined in:
- lib/vapi_server_sdk/types/user_message.rb
Constant Summary collapse
- OMIT =
Object.new
Instance Attribute Summary collapse
-
#additional_properties ⇒ OpenStruct
readonly
Additional properties unmapped to the current class definition.
-
#duration ⇒ Float
readonly
The duration of the message in seconds.
-
#end_time ⇒ Float
readonly
The timestamp when the message ended.
-
#message ⇒ String
readonly
The message content from the user.
-
#role ⇒ String
readonly
The role of the user in the conversation.
-
#seconds_from_start ⇒ Float
readonly
The number of seconds from the start of the conversation.
-
#time ⇒ Float
readonly
The timestamp when the message was sent.
Class Method Summary collapse
-
.from_json(json_object:) ⇒ Vapi::UserMessage
Deserialize a JSON object to an instance of UserMessage.
-
.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(role:, message:, time:, end_time:, seconds_from_start:, duration: OMIT, additional_properties: nil) ⇒ Vapi::UserMessage constructor
-
#to_json(*_args) ⇒ String
Serialize an instance of UserMessage to a JSON object.
Constructor Details
#initialize(role:, message:, time:, end_time:, seconds_from_start:, duration: OMIT, additional_properties: nil) ⇒ Vapi::UserMessage
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 |
# File 'lib/vapi_server_sdk/types/user_message.rb', line 36 def initialize(role:, message:, time:, end_time:, seconds_from_start:, duration: OMIT, additional_properties: nil) @role = role @message = @time = time @end_time = end_time @seconds_from_start = seconds_from_start @duration = duration if duration != OMIT @additional_properties = additional_properties @_field_set = { "role": role, "message": , "time": time, "endTime": end_time, "secondsFromStart": seconds_from_start, "duration": duration }.reject do |_k, v| v == OMIT end end |
Instance Attribute Details
#additional_properties ⇒ OpenStruct (readonly)
Returns Additional properties unmapped to the current class definition.
21 22 23 |
# File 'lib/vapi_server_sdk/types/user_message.rb', line 21 def additional_properties @additional_properties end |
#duration ⇒ Float (readonly)
Returns The duration of the message in seconds.
19 20 21 |
# File 'lib/vapi_server_sdk/types/user_message.rb', line 19 def duration @duration end |
#end_time ⇒ Float (readonly)
Returns The timestamp when the message ended.
15 16 17 |
# File 'lib/vapi_server_sdk/types/user_message.rb', line 15 def end_time @end_time end |
#message ⇒ String (readonly)
Returns The message content from the user.
11 12 13 |
# File 'lib/vapi_server_sdk/types/user_message.rb', line 11 def @message end |
#role ⇒ String (readonly)
Returns The role of the user in the conversation.
9 10 11 |
# File 'lib/vapi_server_sdk/types/user_message.rb', line 9 def role @role end |
#seconds_from_start ⇒ Float (readonly)
Returns The number of seconds from the start of the conversation.
17 18 19 |
# File 'lib/vapi_server_sdk/types/user_message.rb', line 17 def seconds_from_start @seconds_from_start end |
#time ⇒ Float (readonly)
Returns The timestamp when the message was sent.
13 14 15 |
# File 'lib/vapi_server_sdk/types/user_message.rb', line 13 def time @time end |
Class Method Details
.from_json(json_object:) ⇒ Vapi::UserMessage
Deserialize a JSON object to an instance of UserMessage
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 |
# File 'lib/vapi_server_sdk/types/user_message.rb', line 60 def self.from_json(json_object:) struct = JSON.parse(json_object, object_class: OpenStruct) parsed_json = JSON.parse(json_object) role = parsed_json["role"] = parsed_json["message"] time = parsed_json["time"] end_time = parsed_json["endTime"] seconds_from_start = parsed_json["secondsFromStart"] duration = parsed_json["duration"] new( role: role, message: , time: time, end_time: end_time, seconds_from_start: seconds_from_start, duration: duration, 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.
93 94 95 96 97 98 99 100 |
# File 'lib/vapi_server_sdk/types/user_message.rb', line 93 def self.validate_raw(obj:) obj.role.is_a?(String) != false || raise("Passed value for field obj.role is not the expected type, validation failed.") obj..is_a?(String) != false || raise("Passed value for field obj.message is not the expected type, validation failed.") obj.time.is_a?(Float) != false || raise("Passed value for field obj.time is not the expected type, validation failed.") obj.end_time.is_a?(Float) != false || raise("Passed value for field obj.end_time is not the expected type, validation failed.") obj.seconds_from_start.is_a?(Float) != false || raise("Passed value for field obj.seconds_from_start is not the expected type, validation failed.") obj.duration&.is_a?(Float) != false || raise("Passed value for field obj.duration is not the expected type, validation failed.") end |
Instance Method Details
#to_json(*_args) ⇒ String
Serialize an instance of UserMessage to a JSON object
83 84 85 |
# File 'lib/vapi_server_sdk/types/user_message.rb', line 83 def to_json(*_args) @_field_set&.to_json end |