remote_user.rb
1.1 KB
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
module OmniAuth
module Strategies
class RemoteUser
include OmniAuth::Strategy
option :fields, [:name, :email]
option :uid_field, :email
def call(env)
request = Rack::Request.new env
cookies = request.cookies
response = Rack::Response.new
if cookies['gitlab_session'] != nil and !env['HTTP_REMOTE_USER'].blank?
response.redirect "#{OmniAuth.config.path_prefix}/users/auth/env/"
else
super(env)
end
end
def request_phase
@user_data = {}
@uid = env
return fail!(:no_remote_user) unless @uid
@user_data[:name] = @uid['NAME']
@user_data[:email] = @uid['EMAIL']
@env['omniauth.auth'] = auth_hash
@env['REQUEST_METHOD'] = 'GET'
@env['PATH_INFO'] = "#{OmniAuth.config.path_prefix}/#{name}/callback"
call_app!
end
uid { @uid['NAME'] }
info{ @user_data }
def callback_phase
fail(:invalid_request)
end
def auth_hash
Omniauth::Utils.deep_merge(super, {'uid' => @uid})
end
end
end
end