2024-12-31 14:20:22 +08:00
|
|
|
class User < ApplicationRecord
|
2025-01-02 16:47:26 +08:00
|
|
|
attr_accessor :remember_token
|
2024-12-31 14:20:22 +08:00
|
|
|
# before_save { self.email = email.downcase }
|
|
|
|
before_save { email.downcase! }
|
|
|
|
validates :name, presence: true, length: { maximum: 50 }
|
|
|
|
VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-]+(\.[a-z\d\-]+)*\.[a-z]+\z/i
|
|
|
|
validates :email, presence: true, length: { maximum: 255 },
|
|
|
|
format: { with: VALID_EMAIL_REGEX },
|
|
|
|
uniqueness: true
|
|
|
|
has_secure_password
|
2025-01-03 10:55:42 +08:00
|
|
|
validates :password, presence: true, length: { minimum: 6 }, allow_nil: true
|
2025-01-02 11:59:27 +08:00
|
|
|
|
|
|
|
def User.digest(string)
|
|
|
|
cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST :
|
|
|
|
BCrypt::Engine.cost
|
|
|
|
BCrypt::Password.create(string, cost: cost)
|
|
|
|
end
|
2025-01-02 16:47:26 +08:00
|
|
|
|
|
|
|
def User.new_token
|
|
|
|
SecureRandom.urlsafe_base64
|
|
|
|
end
|
|
|
|
|
|
|
|
def remember
|
|
|
|
self.remember_token = User.new_token
|
|
|
|
update_attribute(:remember_digest, User.digest(remember_token))
|
2025-01-02 17:49:06 +08:00
|
|
|
remember_digest
|
|
|
|
end
|
|
|
|
|
|
|
|
# 返回一个会话令牌,防止会话劫持
|
|
|
|
# 简单起见,直接使用记忆令牌
|
|
|
|
def session_token
|
|
|
|
remember_digest || remember
|
2025-01-02 16:47:26 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
class << self
|
|
|
|
def digest(string)
|
|
|
|
cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST :
|
|
|
|
BCrypt::Engine.cost
|
|
|
|
BCrypt::Password.create(string, cost: cost)
|
|
|
|
end
|
|
|
|
|
|
|
|
def new_token
|
|
|
|
SecureRandom.urlsafe_base64
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def authenticated?(remember_token)
|
2025-01-02 17:17:09 +08:00
|
|
|
return false if remember_digest.nil?
|
2025-01-02 16:47:26 +08:00
|
|
|
BCrypt::Password.new(remember_digest).is_password?(remember_token)
|
|
|
|
end
|
|
|
|
|
|
|
|
def forget
|
|
|
|
update_attribute(:remember_digest, nil)
|
|
|
|
end
|
2024-12-31 14:20:22 +08:00
|
|
|
end
|