Module: ActiveModel::OneTimePassword::InstanceMethodsOnActivation

Defined in:
lib/active_model/one_time_password.rb

Instance Method Summary collapse

Instance Method Details

#authenticate_otp(code, options = {}) ⇒ Object



74
75
76
77
78
79
80
81
82
# File 'lib/active_model/one_time_password.rb', line 74

def authenticate_otp(code, options = {})
  return true if backup_codes_enabled? && authenticate_backup_code(code)

  if otp_counter_based
    otp_counter == authenticate_hotp(code, options)
  else
    authenticate_totp(code, options).present?
  end
end

#backup_codes_enabled?Boolean

Returns:

  • (Boolean)


147
148
149
# File 'lib/active_model/one_time_password.rb', line 147

def backup_codes_enabled?
  self.class.attribute_method?(self.class.otp_backup_codes_column_name)
end

#otp_code(options = {}) ⇒ Object



84
85
86
87
88
89
90
# File 'lib/active_model/one_time_password.rb', line 84

def otp_code(options = {})
  if otp_counter_based
    hotp_code(options)
  else
    totp_code(options)
  end
end

#otp_columnObject



107
108
109
# File 'lib/active_model/one_time_password.rb', line 107

def otp_column
  self.public_send(self.class.otp_column_name)
end

#otp_column=(attr) ⇒ Object



111
112
113
# File 'lib/active_model/one_time_password.rb', line 111

def otp_column=(attr)
  self.public_send("#{self.class.otp_column_name}=", attr)
end

#otp_counterObject



115
116
117
118
119
120
121
# File 'lib/active_model/one_time_password.rb', line 115

def otp_counter
  if self.class.otp_counter_column_name != "otp_counter"
    self.public_send(self.class.otp_counter_column_name)
  else
    super
  end
end

#otp_counter=(attr) ⇒ Object



123
124
125
126
127
128
129
# File 'lib/active_model/one_time_password.rb', line 123

def otp_counter=(attr)
  if self.class.otp_counter_column_name != "otp_counter"
    self.public_send("#{self.class.otp_counter_column_name}=", attr)
  else
    super
  end
end

#otp_regenerate_backup_codesObject



138
139
140
141
142
143
144
145
# File 'lib/active_model/one_time_password.rb', line 138

def otp_regenerate_backup_codes
  otp = ROTP::OTP.new(otp_column)
  backup_codes = Array.new(self.class.otp_backup_codes_count) do
    otp.generate_otp((SecureRandom.random_number(9e5) + 1e5).to_i)
  end

  public_send("#{self.class.otp_backup_codes_column_name}=", backup_codes)
end

#otp_regenerate_counterObject



70
71
72
# File 'lib/active_model/one_time_password.rb', line 70

def otp_regenerate_counter
  self.otp_counter = 1
end

#otp_regenerate_secretObject



66
67
68
# File 'lib/active_model/one_time_password.rb', line 66

def otp_regenerate_secret
  self.otp_column = self.class.otp_random_secret
end

#provisioning_uri(account = nil, options = {}) ⇒ Object



92
93
94
95
96
97
98
99
100
101
102
103
104
105
# File 'lib/active_model/one_time_password.rb', line 92

def provisioning_uri( = nil, options = {})
   ||= self.email if self.respond_to?(:email)
   ||= ""

  if otp_counter_based
    ROTP::HOTP
      .new(otp_column, options)
      .provisioning_uri(, self.otp_counter)
  else
    ROTP::TOTP
      .new(otp_column, options)
      .provisioning_uri()
  end
end

#serializable_hash(options = nil) ⇒ Object



131
132
133
134
135
136
# File 'lib/active_model/one_time_password.rb', line 131

def serializable_hash(options = nil)
  options ||= {}
  options[:except] = Array(options[:except])
  options[:except] << self.class.otp_column_name
  super(options)
end