Class: CandidApiClient::Encounters::V4::Types::Intervention
- Inherits:
-
Object
- Object
- CandidApiClient::Encounters::V4::Types::Intervention
- Defined in:
- lib/candidhealth/encounters/v_4/types/intervention.rb
Constant Summary collapse
- OMIT =
Object.new
Instance Attribute Summary collapse
-
#additional_properties ⇒ OpenStruct
readonly
Additional properties unmapped to the current class definition.
- #category ⇒ CandidApiClient::Encounters::V4::Types::InterventionCategory readonly
-
#description ⇒ String
readonly
“Examples: ‘Birth Control LAC’, ‘Tracking’, ‘Stress Management’, ‘Supplement’, ‘Labs’”.
-
#labs ⇒ Array<CandidApiClient::Encounters::V4::Types::Lab>
readonly
Required when ‘type` is `tests`.
-
#medication ⇒ CandidApiClient::Encounters::V4::Types::Medication
readonly
Required when ‘type` is `allopathic`.
- #name ⇒ String readonly
Class Method Summary collapse
-
.from_json(json_object:) ⇒ CandidApiClient::Encounters::V4::Types::Intervention
Deserialize a JSON object to an instance of Intervention.
-
.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(name:, category:, description: OMIT, medication: OMIT, labs: OMIT, additional_properties: nil) ⇒ CandidApiClient::Encounters::V4::Types::Intervention constructor
-
#to_json(*_args) ⇒ String
Serialize an instance of Intervention to a JSON object.
Constructor Details
#initialize(name:, category:, description: OMIT, medication: OMIT, labs: OMIT, additional_properties: nil) ⇒ CandidApiClient::Encounters::V4::Types::Intervention
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'lib/candidhealth/encounters/v_4/types/intervention.rb', line 41 def initialize(name:, category:, description: OMIT, medication: OMIT, labs: OMIT, additional_properties: nil) @name = name @category = category @description = description if description != OMIT @medication = medication if medication != OMIT @labs = labs if labs != OMIT @additional_properties = additional_properties @_field_set = { "name": name, "category": category, "description": description, "medication": medication, "labs": labs }.reject do |_k, v| v == OMIT end end |
Instance Attribute Details
#additional_properties ⇒ OpenStruct (readonly)
Returns Additional properties unmapped to the current class definition.
26 27 28 |
# File 'lib/candidhealth/encounters/v_4/types/intervention.rb', line 26 def additional_properties @additional_properties end |
#category ⇒ CandidApiClient::Encounters::V4::Types::InterventionCategory (readonly)
17 18 19 |
# File 'lib/candidhealth/encounters/v_4/types/intervention.rb', line 17 def category @category end |
#description ⇒ String (readonly)
Returns “Examples: ‘Birth Control LAC’, ‘Tracking’, ‘Stress Management’, ‘Supplement’, ‘Labs’”.
20 21 22 |
# File 'lib/candidhealth/encounters/v_4/types/intervention.rb', line 20 def description @description end |
#labs ⇒ Array<CandidApiClient::Encounters::V4::Types::Lab> (readonly)
Returns Required when ‘type` is `tests`.
24 25 26 |
# File 'lib/candidhealth/encounters/v_4/types/intervention.rb', line 24 def labs @labs end |
#medication ⇒ CandidApiClient::Encounters::V4::Types::Medication (readonly)
Returns Required when ‘type` is `allopathic`.
22 23 24 |
# File 'lib/candidhealth/encounters/v_4/types/intervention.rb', line 22 def medication @medication end |
#name ⇒ String (readonly)
15 16 17 |
# File 'lib/candidhealth/encounters/v_4/types/intervention.rb', line 15 def name @name end |
Class Method Details
.from_json(json_object:) ⇒ CandidApiClient::Encounters::V4::Types::Intervention
Deserialize a JSON object to an instance of Intervention
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 |
# File 'lib/candidhealth/encounters/v_4/types/intervention.rb', line 63 def self.from_json(json_object:) struct = JSON.parse(json_object, object_class: OpenStruct) parsed_json = JSON.parse(json_object) name = struct["name"] category = struct["category"] description = struct["description"] if parsed_json["medication"].nil? medication = nil else medication = parsed_json["medication"].to_json medication = CandidApiClient::Encounters::V4::Types::Medication.from_json(json_object: medication) end labs = parsed_json["labs"]&.map do |item| item = item.to_json CandidApiClient::Encounters::V4::Types::Lab.from_json(json_object: item) end new( name: name, category: category, description: description, medication: medication, labs: labs, 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.
102 103 104 105 106 107 108 |
# File 'lib/candidhealth/encounters/v_4/types/intervention.rb', line 102 def self.validate_raw(obj:) obj.name.is_a?(String) != false || raise("Passed value for field obj.name is not the expected type, validation failed.") obj.category.is_a?(CandidApiClient::Encounters::V4::Types::InterventionCategory) != false || raise("Passed value for field obj.category is not the expected type, validation failed.") obj.description&.is_a?(String) != false || raise("Passed value for field obj.description is not the expected type, validation failed.") obj.medication.nil? || CandidApiClient::Encounters::V4::Types::Medication.validate_raw(obj: obj.medication) obj.labs&.is_a?(Array) != false || raise("Passed value for field obj.labs is not the expected type, validation failed.") end |
Instance Method Details
#to_json(*_args) ⇒ String
Serialize an instance of Intervention to a JSON object
92 93 94 |
# File 'lib/candidhealth/encounters/v_4/types/intervention.rb', line 92 def to_json(*_args) @_field_set&.to_json end |