Module: Devise::Models::PasswordArchivable

Extended by:
ActiveSupport::Concern
Defined in:
lib/devise-security/models/password_archivable.rb

Overview

PasswordArchivable

Defined Under Namespace

Modules: ClassMethods

Instance Method Summary collapse

Instance Method Details

#archive_countObject



53
54
55
# File 'lib/devise-security/models/password_archivable.rb', line 53

def archive_count
  self.class.password_archiving_count
end

#deny_old_passwordsObject



45
46
47
# File 'lib/devise-security/models/password_archivable.rb', line 45

def deny_old_passwords
  self.class.deny_old_passwords
end

#deny_old_passwords=(count) ⇒ Object



49
50
51
# File 'lib/devise-security/models/password_archivable.rb', line 49

def deny_old_passwords=(count)
  self.class.deny_old_passwords = count
end

#password_archive_included?Boolean

validate is the password used in the past

Returns:

  • (Boolean)


18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
# File 'lib/devise-security/models/password_archivable.rb', line 18

def password_archive_included?
  unless deny_old_passwords.is_a? 1.class
    if deny_old_passwords.is_a?(TrueClass) && archive_count > 0
      self.deny_old_passwords = archive_count
    else
      self.deny_old_passwords = 0
    end
  end

  if self.class.deny_old_passwords > 0 && !self.password.nil?
    old_passwords_including_cur_change = self.old_passwords.order(:id).reverse_order.limit(self.class.deny_old_passwords).to_a
    old_passwords_including_cur_change << OldPassword.new(old_password_params)  # include most recent change in list, but don't save it yet!
    old_passwords_including_cur_change.each do |old_password|
      dummy                    = self.class.new
      dummy.encrypted_password = old_password.encrypted_password
      return true if dummy.valid_password?(password)
    end
  end

  false
end

#password_changed_to_same?Boolean

Returns:

  • (Boolean)


40
41
42
43
# File 'lib/devise-security/models/password_archivable.rb', line 40

def password_changed_to_same?
  pass_change = encrypted_password_change
  pass_change && pass_change.first == pass_change.last
end

#validate_password_archiveObject



13
14
15
# File 'lib/devise-security/models/password_archivable.rb', line 13

def validate_password_archive
  errors.add(:password, :taken_in_past) if encrypted_password_changed? && password_archive_included?
end