debian-mirror-gitlab/lib/gitlab/auth/request_authenticator.rb

34 lines
738 B
Ruby
Raw Normal View History

2018-03-17 18:26:18 +05:30
# Use for authentication only, in particular for Rack::Attack.
# Does not perform authorization of scopes, etc.
module Gitlab
module Auth
class RequestAuthenticator
include UserAuthFinders
attr_reader :request
def initialize(request)
@request = request
end
def user
find_sessionless_user || find_user_from_warden
end
def find_sessionless_user
2018-11-08 19:23:39 +05:30
find_user_from_access_token || find_user_from_feed_token
2018-03-17 18:26:18 +05:30
rescue Gitlab::Auth::AuthenticationError
nil
end
2018-03-27 19:54:05 +05:30
def valid_access_token?(scopes: [])
validate_access_token!(scopes: scopes)
true
rescue Gitlab::Auth::AuthenticationError
false
end
2018-03-17 18:26:18 +05:30
end
end
end