diff options
Diffstat (limited to 'lib/api/helpers.rb')
| -rw-r--r-- | lib/api/helpers.rb | 78 | 
1 files changed, 17 insertions, 61 deletions
| diff --git a/lib/api/helpers.rb b/lib/api/helpers.rb index 67ef329f01f..6e58022a265 100644 --- a/lib/api/helpers.rb +++ b/lib/api/helpers.rb @@ -3,8 +3,6 @@ module API      include Gitlab::Utils      include Helpers::Pagination -    UnauthorizedError = Class.new(StandardError) -      SUDO_HEADER = "HTTP_SUDO".freeze      SUDO_PARAM = :sudo @@ -43,6 +41,8 @@ module API        sudo! +      validate_access_token!(scopes: scopes_registered_for_endpoint) unless sudo? +        @current_user      end @@ -186,6 +186,10 @@ module API        end      end +    def require_pages_enabled! +      not_found! unless user_project.pages_available? +    end +      def can?(object, action, subject = :global)        Ability.allowed?(object, action, subject)      end @@ -324,6 +328,7 @@ module API        finder_params[:archived] = params[:archived]        finder_params[:search] = params[:search] if params[:search]        finder_params[:user] = params.delete(:user) if params[:user] +      finder_params[:custom_attributes] = params[:custom_attributes] if params[:custom_attributes]        finder_params      end @@ -379,67 +384,35 @@ module API      private -    def private_token -      params[APIGuard::PRIVATE_TOKEN_PARAM] || env[APIGuard::PRIVATE_TOKEN_HEADER] -    end - -    def warden -      env['warden'] -    end - -    # Check if the request is GET/HEAD, or if CSRF token is valid. -    def verified_request? -      Gitlab::RequestForgeryProtection.verified?(env) -    end - -    # Check the Rails session for valid authentication details -    def find_user_from_warden -      warden.try(:authenticate) if verified_request? -    end -      def initial_current_user        return @initial_current_user if defined?(@initial_current_user)        begin -        @initial_current_user = Gitlab::Auth::UniqueIpsLimiter.limit_user! { find_current_user } -      rescue APIGuard::UnauthorizedError, UnauthorizedError +        @initial_current_user = Gitlab::Auth::UniqueIpsLimiter.limit_user! { find_current_user! } +      rescue APIGuard::UnauthorizedError          unauthorized!        end      end -    def find_current_user -      user = -        find_user_by_private_token(scopes: scopes_registered_for_endpoint) || -        doorkeeper_guard(scopes: scopes_registered_for_endpoint) || -        find_user_from_warden - -      return nil unless user - -      raise UnauthorizedError unless Gitlab::UserAccess.new(user).allowed? && user.can?(:access_api) - -      user -    end -      def sudo!        return unless sudo_identifier -      return unless initial_current_user + +      unauthorized! unless initial_current_user        unless initial_current_user.admin?          forbidden!('Must be admin to use sudo')        end -      # Only private tokens should be used for the SUDO feature -      unless private_token == initial_current_user.private_token -        forbidden!('Private token must be specified in order to use sudo') +      unless access_token +        forbidden!('Must be authenticated using an OAuth or Personal Access Token to use sudo')        end +      validate_access_token!(scopes: [:sudo]) +        sudoed_user = find_user(sudo_identifier) +      not_found!("User with ID or username '#{sudo_identifier}'") unless sudoed_user -      if sudoed_user -        @current_user = sudoed_user -      else -        not_found!("No user id or username for: #{sudo_identifier}") -      end +      @current_user = sudoed_user      end      def sudo_identifier @@ -479,22 +452,5 @@ module API        exception.status == 500      end - -    # An array of scopes that were registered (using `allow_access_with_scope`) -    # for the current endpoint class. It also returns scopes registered on -    # `API::API`, since these are meant to apply to all API routes. -    def scopes_registered_for_endpoint -      @scopes_registered_for_endpoint ||= -        begin -          endpoint_classes = [options[:for].presence, ::API::API].compact -          endpoint_classes.reduce([]) do |memo, endpoint| -            if endpoint.respond_to?(:allowed_scopes) -              memo.concat(endpoint.allowed_scopes) -            else -              memo -            end -          end -        end -    end    end  end | 
