Class: TrophyApiClient::MultiStageAchievementResponse
- Inherits:
-
Object
- Object
- TrophyApiClient::MultiStageAchievementResponse
- Defined in:
- lib/trophy_api_client/types/multi_stage_achievement_response.rb
Constant Summary collapse
- OMIT =
Object.new
Instance Attribute Summary collapse
-
#achieved_at ⇒ DateTime
readonly
The date and time the achievement was completed, in ISO 8601 format.
-
#additional_properties ⇒ OpenStruct
readonly
Additional properties unmapped to the current class definition.
-
#badge_url ⇒ String
readonly
The URL of the badge image for the achievement, if one has been uploaded.
-
#id ⇒ String
readonly
The unique ID of the achievement.
-
#key ⇒ String
readonly
The key used to reference this achievement in the API.
-
#metric_id ⇒ String
readonly
The ID of the metric associated with this achievement, if any.
-
#metric_name ⇒ String
readonly
The name of the metric associated with this achievement, if any.
-
#metric_value ⇒ Float
readonly
The value of the metric required to complete the achievement, if this achievement is associated with a metric.
-
#name ⇒ String
readonly
The name of this achievement.
Class Method Summary collapse
-
.from_json(json_object:) ⇒ TrophyApiClient::MultiStageAchievementResponse
Deserialize a JSON object to an instance of MultiStageAchievementResponse.
-
.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(id:, name: OMIT, badge_url: OMIT, metric_id: OMIT, metric_value: OMIT, metric_name: OMIT, key: OMIT, achieved_at: OMIT, additional_properties: nil) ⇒ TrophyApiClient::MultiStageAchievementResponse constructor
-
#to_json(*_args) ⇒ String
Serialize an instance of MultiStageAchievementResponse to a JSON object.
Constructor Details
#initialize(id:, name: OMIT, badge_url: OMIT, metric_id: OMIT, metric_value: OMIT, metric_name: OMIT, key: OMIT, achieved_at: OMIT, additional_properties: nil) ⇒ TrophyApiClient::MultiStageAchievementResponse
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 45 def initialize(id:, name: OMIT, badge_url: OMIT, metric_id: OMIT, metric_value: OMIT, metric_name: OMIT, key: OMIT, achieved_at: OMIT, additional_properties: nil) @id = id @name = name if name != OMIT @badge_url = badge_url if badge_url != OMIT @metric_id = metric_id if metric_id != OMIT @metric_value = metric_value if metric_value != OMIT @metric_name = metric_name if metric_name != OMIT @key = key if key != OMIT @achieved_at = achieved_at if achieved_at != OMIT @additional_properties = additional_properties @_field_set = { "id": id, "name": name, "badgeUrl": badge_url, "metricId": metric_id, "metricValue": metric_value, "metricName": metric_name, "key": key, "achievedAt": achieved_at }.reject do |_k, v| v == OMIT end end |
Instance Attribute Details
#achieved_at ⇒ DateTime (readonly)
Returns The date and time the achievement was completed, in ISO 8601 format.
25 26 27 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 25 def achieved_at @achieved_at end |
#additional_properties ⇒ OpenStruct (readonly)
Returns Additional properties unmapped to the current class definition.
27 28 29 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 27 def additional_properties @additional_properties end |
#badge_url ⇒ String (readonly)
Returns The URL of the badge image for the achievement, if one has been uploaded.
14 15 16 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 14 def badge_url @badge_url end |
#id ⇒ String (readonly)
Returns The unique ID of the achievement.
10 11 12 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 10 def id @id end |
#key ⇒ String (readonly)
Returns The key used to reference this achievement in the API.
23 24 25 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 23 def key @key end |
#metric_id ⇒ String (readonly)
Returns The ID of the metric associated with this achievement, if any.
16 17 18 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 16 def metric_id @metric_id end |
#metric_name ⇒ String (readonly)
Returns The name of the metric associated with this achievement, if any.
21 22 23 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 21 def metric_name @metric_name end |
#metric_value ⇒ Float (readonly)
Returns The value of the metric required to complete the achievement, if this achievement is associated with a metric.
19 20 21 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 19 def metric_value @metric_value end |
#name ⇒ String (readonly)
Returns The name of this achievement.
12 13 14 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 12 def name @name end |
Class Method Details
.from_json(json_object:) ⇒ TrophyApiClient::MultiStageAchievementResponse
Deserialize a JSON object to an instance of MultiStageAchievementResponse
74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 74 def self.from_json(json_object:) struct = JSON.parse(json_object, object_class: OpenStruct) parsed_json = JSON.parse(json_object) id = parsed_json["id"] name = parsed_json["name"] badge_url = parsed_json["badgeUrl"] metric_id = parsed_json["metricId"] metric_value = parsed_json["metricValue"] metric_name = parsed_json["metricName"] key = parsed_json["key"] achieved_at = (DateTime.parse(parsed_json["achievedAt"]) unless parsed_json["achievedAt"].nil?) new( id: id, name: name, badge_url: badge_url, metric_id: metric_id, metric_value: metric_value, metric_name: metric_name, key: key, achieved_at: achieved_at, 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.
111 112 113 114 115 116 117 118 119 120 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 111 def self.validate_raw(obj:) obj.id.is_a?(String) != false || raise("Passed value for field obj.id is not the expected type, validation failed.") obj.name&.is_a?(String) != false || raise("Passed value for field obj.name is not the expected type, validation failed.") obj.badge_url&.is_a?(String) != false || raise("Passed value for field obj.badge_url is not the expected type, validation failed.") obj.metric_id&.is_a?(String) != false || raise("Passed value for field obj.metric_id is not the expected type, validation failed.") obj.metric_value&.is_a?(Float) != false || raise("Passed value for field obj.metric_value is not the expected type, validation failed.") obj.metric_name&.is_a?(String) != false || raise("Passed value for field obj.metric_name is not the expected type, validation failed.") obj.key&.is_a?(String) != false || raise("Passed value for field obj.key is not the expected type, validation failed.") obj.achieved_at&.is_a?(DateTime) != false || raise("Passed value for field obj.achieved_at is not the expected type, validation failed.") end |
Instance Method Details
#to_json(*_args) ⇒ String
Serialize an instance of MultiStageAchievementResponse to a JSON object
101 102 103 |
# File 'lib/trophy_api_client/types/multi_stage_achievement_response.rb', line 101 def to_json(*_args) @_field_set&.to_json end |