Commit e601d349 authored by Imre Farkas's avatar Imre Farkas

Merge branch 'fix-actioncable-empty-session-cookie' into 'master'

Fix exception when session cookie is not present

See merge request gitlab-org/gitlab!44113
parents e4ab5db1 10e84a25
...@@ -15,12 +15,14 @@ module ApplicationCable ...@@ -15,12 +15,14 @@ module ApplicationCable
private private
def find_user_from_session_store def find_user_from_session_store
session = ActiveSession.sessions_from_ids([session_id.private_id]).first session = ActiveSession.sessions_from_ids(Array.wrap(session_id)).first
Warden::SessionSerializer.new('rack.session' => session).fetch(:user) Warden::SessionSerializer.new('rack.session' => session).fetch(:user)
end end
def session_id def session_id
Rack::Session::SessionId.new(cookies[Gitlab::Application.config.session_options[:key]]) session_cookie = cookies[Gitlab::Application.config.session_options[:key]]
Rack::Session::SessionId.new(session_cookie).private_id if session_cookie.present?
end end
def notification_payload(_) def notification_payload(_)
......
...@@ -5,27 +5,39 @@ require 'spec_helper' ...@@ -5,27 +5,39 @@ require 'spec_helper'
RSpec.describe ApplicationCable::Connection, :clean_gitlab_redis_shared_state do RSpec.describe ApplicationCable::Connection, :clean_gitlab_redis_shared_state do
let(:session_id) { Rack::Session::SessionId.new('6919a6f1bb119dd7396fadc38fd18d0d') } let(:session_id) { Rack::Session::SessionId.new('6919a6f1bb119dd7396fadc38fd18d0d') }
before do context 'when session cookie is set' do
Gitlab::Redis::SharedState.with do |redis| before do
redis.set("session:gitlab:#{session_id.private_id}", Marshal.dump(session_hash)) Gitlab::Redis::SharedState.with do |redis|
redis.set("session:gitlab:#{session_id.private_id}", Marshal.dump(session_hash))
end
cookies[Gitlab::Application.config.session_options[:key]] = session_id.public_id
end end
cookies[Gitlab::Application.config.session_options[:key]] = session_id.public_id context 'when user is logged in' do
end let(:user) { create(:user) }
let(:session_hash) { { 'warden.user.user.key' => [[user.id], user.encrypted_password[0, 29]] } }
it 'sets current_user' do
connect
expect(connection.current_user).to eq(user)
end
context 'when user is logged in' do context 'with a stale password' do
let(:user) { create(:user) } let(:partial_password_hash) { build(:user, password: 'some_old_password').encrypted_password[0, 29] }
let(:session_hash) { { 'warden.user.user.key' => [[user.id], user.encrypted_password[0, 29]] } } let(:session_hash) { { 'warden.user.user.key' => [[user.id], partial_password_hash] } }
it 'sets current_user' do it 'sets current_user to nil' do
connect connect
expect(connection.current_user).to eq(user) expect(connection.current_user).to be_nil
end
end
end end
context 'with a stale password' do context 'when user is not logged in' do
let(:partial_password_hash) { build(:user, password: 'some_old_password').encrypted_password[0, 29] } let(:session_hash) { {} }
let(:session_hash) { { 'warden.user.user.key' => [[user.id], partial_password_hash] } }
it 'sets current_user to nil' do it 'sets current_user to nil' do
connect connect
...@@ -35,10 +47,18 @@ RSpec.describe ApplicationCable::Connection, :clean_gitlab_redis_shared_state do ...@@ -35,10 +47,18 @@ RSpec.describe ApplicationCable::Connection, :clean_gitlab_redis_shared_state do
end end
end end
context 'when user is not logged in' do context 'when session cookie is not set' do
let(:session_hash) { {} } it 'sets current_user to nil' do
connect
expect(connection.current_user).to be_nil
end
end
context 'when session cookie is an empty string' do
it 'sets current_user to nil' do it 'sets current_user to nil' do
cookies[Gitlab::Application.config.session_options[:key]] = ''
connect connect
expect(connection.current_user).to be_nil expect(connection.current_user).to be_nil
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment