Class: Line::Bot::V2::ChannelAccessToken::ErrorResponse

Inherits:
Object
  • Object
show all
Defined in:
lib/line/bot/v2/channel_access_token/model/error_response.rb

Overview

Error response of the Channel access token

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(error: nil, error_description: nil, **dynamic_attributes) ⇒ ErrorResponse

Returns a new instance of ErrorResponse.

Parameters:

  • error (String, nil) (defaults to: nil)

    Error summary

  • error_description (String, nil) (defaults to: nil)

    Details of the error. Not returned in certain situations.



25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
# File 'lib/line/bot/v2/channel_access_token/model/error_response.rb', line 25

def initialize(
  error: nil,
  error_description: nil,
  **dynamic_attributes
)
  
  @error = error
  @error_description = error_description

  dynamic_attributes.each do |key, value|
    self.class.attr_accessor key

    if value.is_a?(Hash)
      struct_klass = Struct.new(*value.keys.map(&:to_sym))
      struct_values = value.map { |_k, v| v.is_a?(Hash) ? Line::Bot::V2::Utils.hash_to_struct(v) : v }
      instance_variable_set("@#{key}", struct_klass.new(*struct_values))
    else
      instance_variable_set("@#{key}", value)
    end
  end
end

Instance Attribute Details

#errorString?

Returns Error summary.

Returns:

  • (String, nil)

    Error summary



18
19
20
# File 'lib/line/bot/v2/channel_access_token/model/error_response.rb', line 18

def error
  @error
end

#error_descriptionString?

Returns Details of the error. Not returned in certain situations.

Returns:

  • (String, nil)

    Details of the error. Not returned in certain situations.



21
22
23
# File 'lib/line/bot/v2/channel_access_token/model/error_response.rb', line 21

def error_description
  @error_description
end

Class Method Details

.create(args) ⇒ Line::Bot::V2::ChannelAccessToken::ErrorResponse

Create an instance of the class from a hash

Parameters:

  • args (Hash)

    Hash containing all the required attributes

Returns:



50
51
52
53
# File 'lib/line/bot/v2/channel_access_token/model/error_response.rb', line 50

def self.create(args) # steep:ignore
  symbolized_args = Line::Bot::V2::Utils.deep_symbolize(args)
  return new(**symbolized_args) # steep:ignore
end

Instance Method Details

#==(other) ⇒ Boolean

Returns true if the objects are equal, false otherwise.

Parameters:

  • other (Object)

    Object to compare

Returns:

  • (Boolean)

    true if the objects are equal, false otherwise



57
58
59
60
61
62
63
# File 'lib/line/bot/v2/channel_access_token/model/error_response.rb', line 57

def ==(other)
  return false unless self.class == other.class

  instance_variables.all? do |var|
      instance_variable_get(var) == other.instance_variable_get(var)
  end
end

#hashInteger

Returns Hash code of the object.

Returns:

  • (Integer)

    Hash code of the object



66
67
68
# File 'lib/line/bot/v2/channel_access_token/model/error_response.rb', line 66

def hash
  [self.class, *instance_variables.map { |var| instance_variable_get(var) }].hash
end