module ActiveModel::SecurePassword::InstanceMethodsOnActivation
Public Instance Methods
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('notright') # => false
user.authenticate('mUc3m00RsqyRe') # => user
# File activemodel/lib/active_model/secure_password.rb, line 90 def authenticate(unencrypted_password) BCrypt::Password.new(password_digest) == unencrypted_password && self end
Encrypts the password into the password_digest attribute, only if the new password is not blank.
class User < ActiveRecord::Base has_secure_password validations: false end user = User.new user.password = nil user.password_digest # => nil user.password = 'mUc3m00RsqyRe' user.password_digest # => "$2a$10$4LEA7r4YmNHtvlAvHhsYAeZmk/xeUVtMTYqwIvYY76EW5GUqDiP4."
# File activemodel/lib/active_model/secure_password.rb, line 106
def password=(unencrypted_password)
if unencrypted_password.nil?
self.password_digest = nil
elsif unencrypted_password.present?
@password = unencrypted_password
cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST : BCrypt::Engine.cost
self.password_digest = BCrypt::Password.create(unencrypted_password, cost: cost)
end
end # File activemodel/lib/active_model/secure_password.rb, line 116 def password_confirmation=(unencrypted_password) @password_confirmation = unencrypted_password end
© 2004–2016 David Heinemeier Hansson
Licensed under the MIT License.