Class: TrophyApiClient::BaseStreakResponse
- Inherits:
-
Object
- Object
- TrophyApiClient::BaseStreakResponse
- Defined in:
- lib/trophy_api_client/types/base_streak_response.rb
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.
Class Method Summary collapse
-
.from_json(json_object:) ⇒ TrophyApiClient::BaseStreakResponse
Deserialize a JSON object to an instance of BaseStreakResponse.
-
.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:, started: OMIT, period_start: OMIT, period_end: OMIT, expires: OMIT, additional_properties: nil) ⇒ TrophyApiClient::BaseStreakResponse constructor
-
#to_json(*_args) ⇒ String
Serialize an instance of BaseStreakResponse to a JSON object.
Constructor Details
#initialize(length:, frequency:, started: OMIT, period_start: OMIT, period_end: OMIT, expires: OMIT, additional_properties: nil) ⇒ TrophyApiClient::BaseStreakResponse
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
# File 'lib/trophy_api_client/types/base_streak_response.rb', line 37 def initialize(length:, frequency:, started: OMIT, period_start: OMIT, period_end: OMIT, expires: OMIT, additional_properties: nil) @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 = { "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.
22 23 24 |
# File 'lib/trophy_api_client/types/base_streak_response.rb', line 22 def additional_properties @additional_properties end |
#expires ⇒ String (readonly)
Returns The date the streak will expire if the user does not increment a metric.
20 21 22 |
# File 'lib/trophy_api_client/types/base_streak_response.rb', line 20 def expires @expires end |
#frequency ⇒ TrophyApiClient::StreakFrequency (readonly)
Returns The frequency of the streak.
12 13 14 |
# File 'lib/trophy_api_client/types/base_streak_response.rb', line 12 def frequency @frequency end |
#length ⇒ Integer (readonly)
Returns The length of the user’s current streak.
10 11 12 |
# File 'lib/trophy_api_client/types/base_streak_response.rb', line 10 def length @length end |
#period_end ⇒ String (readonly)
Returns The end date of the current streak period.
18 19 20 |
# File 'lib/trophy_api_client/types/base_streak_response.rb', line 18 def period_end @period_end end |
#period_start ⇒ String (readonly)
Returns The start date of the current streak period.
16 17 18 |
# File 'lib/trophy_api_client/types/base_streak_response.rb', line 16 def period_start @period_start end |
#started ⇒ String (readonly)
Returns The date the streak started.
14 15 16 |
# File 'lib/trophy_api_client/types/base_streak_response.rb', line 14 def started @started end |
Class Method Details
.from_json(json_object:) ⇒ TrophyApiClient::BaseStreakResponse
Deserialize a JSON object to an instance of BaseStreakResponse
62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 |
# File 'lib/trophy_api_client/types/base_streak_response.rb', line 62 def self.from_json(json_object:) struct = JSON.parse(json_object, object_class: OpenStruct) parsed_json = JSON.parse(json_object) 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( 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.
95 96 97 98 99 100 101 102 |
# File 'lib/trophy_api_client/types/base_streak_response.rb', line 95 def self.validate_raw(obj:) 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 BaseStreakResponse to a JSON object
85 86 87 |
# File 'lib/trophy_api_client/types/base_streak_response.rb', line 85 def to_json(*_args) @_field_set&.to_json end |