Class: TrophyApiClient::StreakResponse
- Inherits:
-
Object
- Object
- TrophyApiClient::StreakResponse
- Defined in:
- lib/trophy_api_client/types/streak_response.rb
Overview
An object representing the user’s streak.
Constant Summary collapse
- OMIT =
Object.new
Instance Attribute Summary collapse
-
#additional_properties ⇒ OpenStruct
readonly
Additional properties unmapped to the current class definition.
-
#expires ⇒ String
readonly
The date the streak will expire if the user does not increment a metric.
-
#frequency ⇒ TrophyApiClient::StreakFrequency
readonly
The frequency of the streak.
-
#length ⇒ Integer
readonly
The length of the user’s current streak.
-
#period_end ⇒ String
readonly
The end date of the current streak period.
-
#period_start ⇒ String
readonly
The start date of the current streak period.
-
#started ⇒ String
readonly
The date the streak started.
-
#streak_history ⇒ Array<TrophyApiClient::StreakResponseStreakHistoryItem>
readonly
A list of the user’s past streak periods up through the current period.
Class Method Summary collapse
-
.from_json(json_object:) ⇒ TrophyApiClient::StreakResponse
Deserialize a JSON object to an instance of StreakResponse.
-
.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(length:, frequency:, streak_history: OMIT, started: OMIT, period_start: OMIT, period_end: OMIT, expires: OMIT, additional_properties: nil) ⇒ TrophyApiClient::StreakResponse constructor
-
#to_json(*_args) ⇒ String
Serialize an instance of StreakResponse to a JSON object.
Constructor Details
#initialize(length:, frequency:, streak_history: OMIT, started: OMIT, period_start: OMIT, period_end: OMIT, expires: OMIT, additional_properties: nil) ⇒ TrophyApiClient::StreakResponse
44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 44 def initialize(length:, frequency:, streak_history: OMIT, started: OMIT, period_start: OMIT, period_end: OMIT, expires: OMIT, additional_properties: nil) @streak_history = streak_history if streak_history != OMIT @length = length @frequency = frequency @started = started if started != OMIT @period_start = period_start if period_start != OMIT @period_end = period_end if period_end != OMIT @expires = expires if expires != OMIT @additional_properties = additional_properties @_field_set = { "streakHistory": streak_history, "length": length, "frequency": frequency, "started": started, "periodStart": period_start, "periodEnd": period_end, "expires": expires }.reject do |_k, v| v == OMIT end end |
Instance Attribute Details
#additional_properties ⇒ OpenStruct (readonly)
Returns Additional properties unmapped to the current class definition.
27 28 29 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 27 def additional_properties @additional_properties end |
#expires ⇒ String (readonly)
Returns The date the streak will expire if the user does not increment a metric.
25 26 27 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 25 def expires @expires end |
#frequency ⇒ TrophyApiClient::StreakFrequency (readonly)
Returns The frequency of the streak.
17 18 19 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 17 def frequency @frequency end |
#length ⇒ Integer (readonly)
Returns The length of the user’s current streak.
15 16 17 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 15 def length @length end |
#period_end ⇒ String (readonly)
Returns The end date of the current streak period.
23 24 25 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 23 def period_end @period_end end |
#period_start ⇒ String (readonly)
Returns The start date of the current streak period.
21 22 23 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 21 def period_start @period_start end |
#started ⇒ String (readonly)
Returns The date the streak started.
19 20 21 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 19 def started @started end |
#streak_history ⇒ Array<TrophyApiClient::StreakResponseStreakHistoryItem> (readonly)
Returns A list of the user’s past streak periods up through the current period. Each period includes the start and end dates and the length of the streak.
13 14 15 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 13 def streak_history @streak_history end |
Class Method Details
.from_json(json_object:) ⇒ TrophyApiClient::StreakResponse
Deserialize a JSON object to an instance of StreakResponse
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 71 def self.from_json(json_object:) struct = JSON.parse(json_object, object_class: OpenStruct) parsed_json = JSON.parse(json_object) streak_history = parsed_json["streakHistory"]&.map do |item| item = item.to_json TrophyApiClient::StreakResponseStreakHistoryItem.from_json(json_object: item) end length = parsed_json["length"] frequency = parsed_json["frequency"] started = parsed_json["started"] period_start = parsed_json["periodStart"] period_end = parsed_json["periodEnd"] expires = parsed_json["expires"] new( streak_history: streak_history, length: length, frequency: frequency, started: started, period_start: period_start, period_end: period_end, expires: expires, 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.
109 110 111 112 113 114 115 116 117 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 109 def self.validate_raw(obj:) obj.streak_history&.is_a?(Array) != false || raise("Passed value for field obj.streak_history is not the expected type, validation failed.") obj.length.is_a?(Integer) != false || raise("Passed value for field obj.length is not the expected type, validation failed.") obj.frequency.is_a?(TrophyApiClient::StreakFrequency) != false || raise("Passed value for field obj.frequency is not the expected type, validation failed.") obj.started&.is_a?(String) != false || raise("Passed value for field obj.started is not the expected type, validation failed.") obj.period_start&.is_a?(String) != false || raise("Passed value for field obj.period_start is not the expected type, validation failed.") obj.period_end&.is_a?(String) != false || raise("Passed value for field obj.period_end is not the expected type, validation failed.") obj.expires&.is_a?(String) != false || raise("Passed value for field obj.expires is not the expected type, validation failed.") end |
Instance Method Details
#to_json(*_args) ⇒ String
Serialize an instance of StreakResponse to a JSON object
99 100 101 |
# File 'lib/trophy_api_client/types/streak_response.rb', line 99 def to_json(*_args) @_field_set&.to_json end |