diff options
Diffstat (limited to 'lib/gitlab/auth.rb')
| -rw-r--r-- | lib/gitlab/auth.rb | 22 | 
1 files changed, 16 insertions, 6 deletions
| diff --git a/lib/gitlab/auth.rb b/lib/gitlab/auth.rb index 3fd81759d25..87aeb76b66a 100644 --- a/lib/gitlab/auth.rb +++ b/lib/gitlab/auth.rb @@ -13,11 +13,6 @@ module Gitlab      # Default scopes for OAuth applications that don't define their own      DEFAULT_SCOPES = [:api].freeze -    AVAILABLE_SCOPES = (API_SCOPES + REGISTRY_SCOPES).freeze - -    # Other available scopes -    OPTIONAL_SCOPES = (AVAILABLE_SCOPES + OPENID_SCOPES - DEFAULT_SCOPES).freeze -      class << self        include Gitlab::CurrentSettings @@ -132,7 +127,7 @@ module Gitlab          token = PersonalAccessTokensFinder.new(state: 'active').find_by(token: password) -        if token && valid_scoped_token?(token, AVAILABLE_SCOPES) +        if token && valid_scoped_token?(token, available_scopes)            Gitlab::Auth::Result.new(token.user, nil, :personal_token, abilities_for_scope(token.scopes))          end        end @@ -230,6 +225,21 @@ module Gitlab        def read_user_scope_authentication_abilities          []        end + +      def available_scopes +        API_SCOPES + registry_scopes +      end + +      # Other available scopes +      def optional_scopes +        available_scopes + OPENID_SCOPES - DEFAULT_SCOPES +      end + +      def registry_scopes +        return [] unless Gitlab.config.registry.enabled + +        REGISTRY_SCOPES +      end      end    end  end | 
