rails5.2で簡単なチャットアプリを作成中です。
シンプルなチャットは動作確認できたので、次に
ログイン済みのuserのみチャットを利用できるようにしてる所です。
以下を参考にしました。
【ActionCable】チャンネル接続/購読時にユーザ認証を行う
ログイン部分は、deviceは使わずrailsチュートリアルを参考に実装しました。
以下の流れにおいて2で、クッキーからuser_idが取れずに居ます。
1.ログイン時、sessionコントローラにてクッキーにuser_idをセット
2.ActionCableのconnect時、クッキーから取得、current_userとして返す
cookies.signed
cookies.encrypted
どちらで試しても同じでした。
分かる方教えていただけないでしょうか?
宜しくお願いします。
/app/channels/application_cable/connection.rb
ruby
1module ApplicationCable 2 class Connection < ActionCable::Connection::Base 3 identified_by :current_user 4 5 def connect 6 self.current_user = find_verified_user 7 end 8 9 protected 10 def find_verified_user 11 12 # どちらも空になる 13 logger.debug cookies.signed[:user_id] 14 logger.debug cookies.encrypted[:user_id] 15 if current_user = User.find_by(id: cookies.signed[:user_id]) 16 current_user 17 else 18 reject_unauthorized_connection 19 end 20 end 21 end 22end 23
/app/controllers/sessions_controller.rb
ruby
1class SessionsController < ApplicationController 2 def new 3 end 4 5 def create 6 user = User.find_by(email: params[:session][:email].downcase) 7 if user && user.authenticate(params[:session][:password]) 8 if user.activated? 9 log_in(user) 10 11 # chatで利用するため、Cookieにuser_idを署名付きで保存する 12 cookies.signed[:user_id] = user.id 13 cookies.encrypted[:user_id] = user.id 14 15 16 params[:session][:remember_me] == '1' ? remember(user) : forget(user) 17 redirect_back_or user 18 else 19 message = "アカウントがアクティブ化されていません. " 20 message += "メールをご確認ください." 21 flash[:warning] = message 22 redirect_to root_url 23 end 24 else 25 flash.now[:danger] = "メール / パスワードの組み合わせが正しくありません" 26 render 'new' 27 end 28 end 29 30 def destroy 31 log_out if logged_in? 32 redirect_to root_url 33 end 34 35end 36
---同日追記----
ログイン後、他の画面に遷移後デバッグしたところ
クッキーの値が取得できてませんでした。
ActionCableは関係ないようです。
この辺り(クッキーの保存期間など)を今から調査してまた追記致します。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。