Class: Line::Bot::V2::ChannelAccessToken::VerifyChannelAccessTokenResponse

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

Overview

Verification result

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(client_id:, expires_in:, scope: nil, **dynamic_attributes) ⇒ VerifyChannelAccessTokenResponse

Returns a new instance of VerifyChannelAccessTokenResponse.

Parameters:

  • client_id (String)

    The channel ID for which the channel access token was issued.

  • expires_in (Integer)

    Number of seconds before the channel access token expires.

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

    Permissions granted to the channel access token.



29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# File 'lib/line/bot/v2/channel_access_token/model/verify_channel_access_token_response.rb', line 29

def initialize(
  client_id:,
  expires_in:,
  scope: nil,
  **dynamic_attributes
)
  
  @client_id = client_id
  @expires_in = expires_in
  @scope = scope

  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

#client_idString

Returns The channel ID for which the channel access token was issued.

Returns:

  • (String)

    The channel ID for which the channel access token was issued.



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

def client_id
  @client_id
end

#expires_inInteger

Returns Number of seconds before the channel access token expires.

Returns:

  • (Integer)

    Number of seconds before the channel access token expires.



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

def expires_in
  @expires_in
end

#scopeString?

Returns Permissions granted to the channel access token.

Returns:

  • (String, nil)

    Permissions granted to the channel access token.



24
25
26
# File 'lib/line/bot/v2/channel_access_token/model/verify_channel_access_token_response.rb', line 24

def scope
  @scope
end

Class Method Details

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

Create an instance of the class from a hash

Parameters:

  • args (Hash)

    Hash containing all the required attributes

Returns:



56
57
58
59
# File 'lib/line/bot/v2/channel_access_token/model/verify_channel_access_token_response.rb', line 56

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



63
64
65
66
67
68
69
# File 'lib/line/bot/v2/channel_access_token/model/verify_channel_access_token_response.rb', line 63

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



72
73
74
# File 'lib/line/bot/v2/channel_access_token/model/verify_channel_access_token_response.rb', line 72

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