1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
|
# frozen_string_literal: true
module ApplicationCable
class Connection < ActionCable::Connection::Base
include Logging
include Gitlab::Auth::AuthFinders
identified_by :current_user
public :request
def connect
self.current_user = find_user_from_bearer_token || find_user_from_session_store
rescue Gitlab::Auth::AuthenticationError
reject_unauthorized_connection
end
private
def find_user_from_session_store
session = ActiveSession.sessions_from_ids(Array.wrap(session_id)).first
Warden::SessionSerializer.new('rack.session' => session).fetch(:user)
end
def session_id
session_cookie = cookies[Gitlab::Application.config.session_options[:key]]
Rack::Session::SessionId.new(session_cookie).private_id if session_cookie.present?
end
def notification_payload(_)
super.merge!(params: request.params)
end
end
end
|