2017-04-06 13 views
2

このガイドに従って、WebSocketを使用してチャット機能を作成してください。 https://www.sitepoint.com/rails-and-actioncable-adding-advanced-features/env ['warden']がRails 5で動作しない

私は標準Deviseフォームでアプリにログオンしても、env['warden'].userが何も戻ってこないという問題があります。

そして、私は(今コメントしている)別の方法を使用する場合 - それは間違ったユーザーを返す

module ApplicationCable 
    class Connection < ActionCable::Connection::Base 
    identified_by :current_user 

    def connect 
     self.current_user = find_verified_user 
     logger.add_tags 'ActionCable', current_user.email 
    end 

    protected 

    def find_verified_user # this checks whether a user is authenticated with devise 
     verified_user = env['warden'].user 

     if verified_user 
     verified_user 
     else 
     reject_unauthorized_connection 
     end 
    end 

    # def find_verified_user 
    #  user_id = request.headers['HTTP_AUTHORIZATION'] 
    #  if verified_user = User.find_by(user_id) 
    #  verified_user 
    #  else 
    #  reject_unauthorized_connection 
    #  end 
    # end 

    end 
end 

ログは

Started GET "/cable/" [WebSocket] for 127.0.0.1 at 2017-04-06 17:40:17 +0300 
Successfully upgraded to WebSocket (REQUEST_METHOD: GET, HTTP_CONNECTION: Upgrade, HTTP_UPGRADE: websocket) 
An unauthorized connection attempt was rejected 
Failed to upgrade to WebSocket (REQUEST_METHOD: GET, HTTP_CONNECTION: Upgrade, HTTP_UPGRADE: websocket) 

答えて

4

が、私はこの記事に解決策を見つけたと言う https://rubytutorial.io/actioncable-devise-authentication/

イムどのように動作するかはわかりませんが、それは取引を行います。それは、同様の問題を抱えている人にとってどのように役立つでしょう。

module ApplicationCable 
    class Connection < ActionCable::Connection::Base 
    identified_by :current_user 

    def connect 
     self.current_user = find_verified_user 
     logger.add_tags 'ActionCable', current_user.email 
    end 

    protected 
    def find_verified_user 
     verified_user = User.find_by(id: cookies.signed['user.id']) 
     if verified_user && cookies.signed['user.expires_at'] > Time.now 
     verified_user 
     else 
     reject_unauthorized_connection 
     end 
    end 

    end 
end 

そして私はまた

Warden::Manager.after_set_user do |user,auth,opts| 
    scope = opts[:scope] 
    auth.cookies.signed["#{scope}.id"] = user.id 
    auth.cookies.signed["#{scope}.expires_at"] = 60.minutes.from_now 
end 

Warden::Manager.before_logout do |user, auth, opts| 
    scope = opts[:scope] 
    auth.cookies.signed["#{scope}.id"] = nil 
    auth.cookies.signed["#{scope}.expires_at"] = nil 
end 
+0

パーフェクトファイル/config/initializers/warden_hooks.rb作成した、本当にありがとうございました!魅力的な仕事をした – DaniG2k

関連する問題