Class: Pinnacle::Call
- Inherits:
-
Object
- Object
- Pinnacle::Call
- Defined in:
- lib/rcs/types/call.rb
Constant Summary collapse
- OMIT =
Object.new
Instance Attribute Summary collapse
-
#action_type ⇒ String
readonly
The type of action being sent.
-
#additional_properties ⇒ OpenStruct
readonly
Additional properties unmapped to the current class definition.
-
#payload ⇒ String
readonly
The number to call in E.
-
#title ⇒ String
readonly
The title for the call action.
Class Method Summary collapse
-
.from_json(json_object:) ⇒ Pinnacle::Call
Deserialize a JSON object to an instance of Call.
-
.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(action_type:, title:, payload:, additional_properties: nil) ⇒ Pinnacle::Call constructor
-
#to_json(*_args) ⇒ String
Serialize an instance of Call to a JSON object.
Constructor Details
#initialize(action_type:, title:, payload:, additional_properties: nil) ⇒ Pinnacle::Call
27 28 29 30 31 32 33 |
# File 'lib/rcs/types/call.rb', line 27 def initialize(action_type:, title:, payload:, additional_properties: nil) @action_type = action_type @title = title @payload = payload @additional_properties = additional_properties @_field_set = { "action_type": action_type, "title": title, "payload": payload } end |
Instance Attribute Details
#action_type ⇒ String (readonly)
Returns The type of action being sent.
9 10 11 |
# File 'lib/rcs/types/call.rb', line 9 def action_type @action_type end |
#additional_properties ⇒ OpenStruct (readonly)
Returns Additional properties unmapped to the current class definition.
15 16 17 |
# File 'lib/rcs/types/call.rb', line 15 def additional_properties @additional_properties end |
#payload ⇒ String (readonly)
Returns The number to call in E. 164 format. Maximum length is 1000 characters.
13 14 15 |
# File 'lib/rcs/types/call.rb', line 13 def payload @payload end |
#title ⇒ String (readonly)
Returns The title for the call action. Maximum length is 25 characters.
11 12 13 |
# File 'lib/rcs/types/call.rb', line 11 def title @title end |
Class Method Details
.from_json(json_object:) ⇒ Pinnacle::Call
Deserialize a JSON object to an instance of Call
39 40 41 42 43 44 45 46 47 48 49 50 51 |
# File 'lib/rcs/types/call.rb', line 39 def self.from_json(json_object:) struct = JSON.parse(json_object, object_class: OpenStruct) parsed_json = JSON.parse(json_object) action_type = parsed_json["action_type"] title = parsed_json["title"] payload = parsed_json["payload"] new( action_type: action_type, title: title, payload: payload, 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.
66 67 68 69 70 |
# File 'lib/rcs/types/call.rb', line 66 def self.validate_raw(obj:) obj.action_type.is_a?(String) != false || raise("Passed value for field obj.action_type is not the expected type, validation failed.") obj.title.is_a?(String) != false || raise("Passed value for field obj.title is not the expected type, validation failed.") obj.payload.is_a?(String) != false || raise("Passed value for field obj.payload is not the expected type, validation failed.") end |
Instance Method Details
#to_json(*_args) ⇒ String
Serialize an instance of Call to a JSON object
56 57 58 |
# File 'lib/rcs/types/call.rb', line 56 def to_json(*_args) @_field_set&.to_json end |