diff options
| author | Lin Jen-Shin <godfat@godfat.org> | 2016-10-04 02:38:25 +0800 | 
|---|---|---|
| committer | Lin Jen-Shin <godfat@godfat.org> | 2016-10-04 02:38:25 +0800 | 
| commit | f39ba1bb5ed9c2421e60a618f71373c5d8dc94e9 (patch) | |
| tree | e5ad67c48bdc2d520b84d735225ff7eac4c7da84 /lib/api/api_guard.rb | |
| parent | db6b2b18990297d98bd74af1d2f475d0d42ec443 (diff) | |
| parent | a1aea3266e4b90869d5a9bcc334272996ab80fda (diff) | |
| download | gitlab-ce-f39ba1bb5ed9c2421e60a618f71373c5d8dc94e9.tar.gz | |
Merge remote-tracking branch 'upstream/master' into pipeline-emails
* upstream/master: (372 commits)
  Enable Lint/StringConversionInInterpolation cop and autocorrect offenses
  resolve duplicated changelog entry
  credit myself :smile:
  change determine conditions
  override subject method in devise mailer
  follow the styleguide: Don't use parentheses around a literal
  wrap subject with method subject
  move spec back into shared example `an email sent from GitLab`
  stub config settings in spec
  remove empty line at block body end
  remove extra entry
  create new test in `spec/mailers/notify_spec.rb`
  move changelog to 8.13
  add configurable email subject suffix
  Fixes sidebar navigation.
  Convert "SSH Keys" Spinach features to RSpec
  Enable import/export back for non-admins
  Update gitlab-shell to 3.6.3
  Updated artwork of empty group state.
  Better empty state for Groups view.
  ...
Diffstat (limited to 'lib/api/api_guard.rb')
| -rw-r--r-- | lib/api/api_guard.rb | 56 | 
1 files changed, 13 insertions, 43 deletions
| diff --git a/lib/api/api_guard.rb b/lib/api/api_guard.rb index 7e67edb203a..8cc7a26f1fa 100644 --- a/lib/api/api_guard.rb +++ b/lib/api/api_guard.rb @@ -33,46 +33,29 @@ module API        #        # If the token is revoked, then it raises RevokedError.        # -      # If the token is not found (nil), then it raises TokenNotFoundError. +      # If the token is not found (nil), then it returns nil        #        # Arguments:        #        #   scopes: (optional) scopes required for this guard.        #           Defaults to empty array.        # -      def doorkeeper_guard!(scopes: []) -        if (access_token = find_access_token).nil? -          raise TokenNotFoundError - -        else -          case validate_access_token(access_token, scopes) -          when Oauth2::AccessTokenValidationService::INSUFFICIENT_SCOPE -            raise InsufficientScopeError.new(scopes) -          when Oauth2::AccessTokenValidationService::EXPIRED -            raise ExpiredError -          when Oauth2::AccessTokenValidationService::REVOKED -            raise RevokedError -          when Oauth2::AccessTokenValidationService::VALID -            @current_user = User.find(access_token.resource_owner_id) -          end -        end -      end -        def doorkeeper_guard(scopes: []) -        if access_token = find_access_token -          case validate_access_token(access_token, scopes) -          when Oauth2::AccessTokenValidationService::INSUFFICIENT_SCOPE -            raise InsufficientScopeError.new(scopes) +        access_token = find_access_token +        return nil unless access_token + +        case validate_access_token(access_token, scopes) +        when Oauth2::AccessTokenValidationService::INSUFFICIENT_SCOPE +          raise InsufficientScopeError.new(scopes) -          when Oauth2::AccessTokenValidationService::EXPIRED -            raise ExpiredError +        when Oauth2::AccessTokenValidationService::EXPIRED +          raise ExpiredError -          when Oauth2::AccessTokenValidationService::REVOKED -            raise RevokedError +        when Oauth2::AccessTokenValidationService::REVOKED +          raise RevokedError -          when Oauth2::AccessTokenValidationService::VALID -            @current_user = User.find(access_token.resource_owner_id) -          end +        when Oauth2::AccessTokenValidationService::VALID +          @current_user = User.find(access_token.resource_owner_id)          end        end @@ -96,19 +79,6 @@ module API      end      module ClassMethods -      # Installs the doorkeeper guard on the whole Grape API endpoint. -      # -      # Arguments: -      # -      #   scopes: (optional) scopes required for this guard. -      #           Defaults to empty array. -      # -      def guard_all!(scopes: []) -        before do -          guard! scopes: scopes -        end -      end -        private        def install_error_responders(base) | 
