Methods
- N
Class Public methods
new(attribute, reset_token:, algorithm:) Link
# File activemodel/lib/active_model/secure_password.rb, line 265 def initialize(attribute, reset_token:, algorithm:) attr_reader attribute define_method("#{attribute}=") do |unencrypted_password| if unencrypted_password.nil? instance_variable_set("@#{attribute}", nil) self.public_send("#{attribute}_digest=", nil) elsif !unencrypted_password.empty? instance_variable_set("@#{attribute}", unencrypted_password) password_digest = algorithm.hash_password(unencrypted_password) self.public_send("#{attribute}_digest=", password_digest) end end attr_accessor :"#{attribute}_confirmation", :"#{attribute}_challenge" # Returns +self+ if the password is correct, otherwise +false+. # # class User < ActiveRecord::Base # has_secure_password validations: false # end # # user = User.new(name: 'david', password: 'mUc3m00RsqyRe') # user.save # user.authenticate_password('notright') # => false # user.authenticate_password('mUc3m00RsqyRe') # => user define_method("authenticate_#{attribute}") do |unencrypted_password| attribute_digest = public_send("#{attribute}_digest") attribute_digest.present? && algorithm.verify_password(unencrypted_password, attribute_digest) && self end # Returns the salt, a small chunk of random data added to the password before it's hashed. define_method("#{attribute}_salt") do attribute_digest = public_send("#{attribute}_digest") attribute_digest.present? ? algorithm.password_salt(attribute_digest) : nil end alias_method :authenticate, :authenticate_password if attribute == :password if reset_token # Returns the class-level configured reset token for the password. define_method("#{attribute}_reset_token") do generate_token_for(:"#{attribute}_reset") end end define_method("#{attribute}_algorithm") do algorithm.algorithm_name end end