【#100DaysOfCode】Day35 Railsチュートリアル 11章 アカウントの有効化:終
11章、ほとんど理解してないので備忘録として残しておく。
Day35
動いたけど理解してないコードをメモしておく
理解してないコード
- authentificated?メソッド
# app/models/user.rb class User < ApplicationRecord attr_accessor :remember_token, :activation_token before_save :downcase_email before_create :create_activation_digest validates :name, presence: true, length: { maximum: 50 } VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/i validates :email, presence: true, length: { maximum: 255 }, format: { with: VALID_EMAIL_REGEX }, uniqueness: { case_sensitive: false } has_secure_password validates :password, presence: true, length: { minimum: 6 }, allow_nil: true def User.digest(string) cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST : BCrypt::Engine.cost BCrypt::Password.create(string, cost: cost) end def User.new_token SecureRandom.urlsafe_base64 end def remember self.remember_token = User.new_token self.update_attribute(:remember_digest, User.digest(remember_token)) end def forget self.update_attribute(:remember_digest, nil) end # ------------------------------------------------------------ # 渡されたトークンがダイジェストと一致したらtrueを返す def authenticated?(attribute, token) digest = self.send("#{attribute}_digest") return false if digest.nil? BCrypt::Password.new(digest).is_password?(token) end # ------------------------------------------------------------ def activate update_attribute(:activated, true) update_attribute(:activated_at, Time.zone.now) end def send_activation_email UserMailer.account_activation(self).deliver_now end private def downcase_email self.email = self.email.downcase end def create_activation_digest self.activation_token = User.new_token self.activation_digest = User.digest(self.activation_token) # @user.activation_digest => ハッシュ値 end end
- helperで作成したcurrent_userメソッド
module SessionsHelper # 渡されたユーザーでログインする def log_in(user) session[:user_id] = user.id end # ユーザーを永続的に復元できるようになった def remember(user) user.remember # => DB: remember_digest cookies.permanent.signed[:user_id] = user.id cookies.permanent[:remember_token] = user.remember_token end def forget(user) user.forget cookies.delete(:user_id) cookies.delete(:remember_token) end # ------------------------------------------------------------------------------ def current_user?(user) user == current_user end def current_user if (user_id = session[:user_id]) @current_user ||= User.find_by(id: user_id) elsif (user_id = cookies.signed[:user_id]) # raise user = User.find_by(id: user_id) if user && user.authenticated?(:remember, cookies[:remember_token]) log_in user @current_user = user end end end # ------------------------------------------------------------------------------ def logged_in? !current_user.nil? end # 現在のユーザーをログアウトする def log_out forget(current_user) session.delete(:user_id) @current_user = nil end # 記憶したURL (もしくはデフォルト値) にリダイレクト def redirect_back_or(default) redirect_to(session[:forwarding_url] || default) session.delete(:forwarding_url) end # アクセスしようとしたURLを覚えておく def store_location session[:forwarding_url] = request.original_url if request.get? end end
- sessions_helper_test.rb全部
# test/helpers/sessions_helper_test.rb
require 'test_helper' class SessionsHelperTest < ActionView::TestCase def setup @user = users(:michael) remember(@user) end test "current_user returns right user when session is nil" do assert_equal @user, current_user assert is_logged_in? end test "current_user returns nil when remember digest is wrong" do @user.update_attribute(:remember_digest, User.digest(User.new_token)) assert_nil current_user end end
- メタプログラミング:ほーんて感じ(やばい)
結論:ほぼ何もわからないということが、わかった!!
とりあえず、「アカウントの有効化周りは要復習」ってことだな