diff options
| author | Simon Knox <psimyn@gmail.com> | 2018-01-15 21:14:43 +1100 | 
|---|---|---|
| committer | Simon Knox <psimyn@gmail.com> | 2018-01-15 21:14:43 +1100 | 
| commit | 5a062dfac78ef19ef726681ccde18b6f5def6108 (patch) | |
| tree | 9aa086322d60aec3c54372fc74e6d497650b56f6 /lib | |
| parent | e2f82f4a45af7116cd8cf9630ce026ec79216799 (diff) | |
| parent | f402762d2c315f462fb3c805990b9842953bc8dc (diff) | |
| download | gitlab-ce-5a062dfac78ef19ef726681ccde18b6f5def6108.tar.gz | |
Merge branch 'master' of gitlab.com:gitlab-org/gitlab-ce into dispatcher-projects-efi
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/gitlab/auth/blocked_user_tracker.rb | 36 | ||||
| -rw-r--r-- | lib/gitlab/auth/user_auth_finders.rb | 4 | ||||
| -rw-r--r-- | lib/gitlab/git/conflict/resolver.rb | 2 | ||||
| -rw-r--r-- | lib/gitlab/gitaly_client/conflict_files_stitcher.rb | 47 | ||||
| -rw-r--r-- | lib/gitlab/gitaly_client/conflicts_service.rb | 38 | 
5 files changed, 90 insertions, 37 deletions
| diff --git a/lib/gitlab/auth/blocked_user_tracker.rb b/lib/gitlab/auth/blocked_user_tracker.rb new file mode 100644 index 00000000000..dae03a179e4 --- /dev/null +++ b/lib/gitlab/auth/blocked_user_tracker.rb @@ -0,0 +1,36 @@ +# frozen_string_literal: true +module Gitlab +  module Auth +    class BlockedUserTracker +      ACTIVE_RECORD_REQUEST_PARAMS = 'action_dispatch.request.request_parameters' + +      def self.log_if_user_blocked(env) +        message = env.dig('warden.options', :message) + +        # Devise calls User#active_for_authentication? on the User model and then +        # throws an exception to Warden with User#inactive_message: +        # https://github.com/plataformatec/devise/blob/v4.2.1/lib/devise/hooks/activatable.rb#L8 +        # +        # Since Warden doesn't pass the user record to the failure handler, we +        # need to do a database lookup with the username. We can limit the +        # lookups to happen when the user was blocked by checking the inactive +        # message passed along by Warden. +        return unless message == User::BLOCKED_MESSAGE + +        login = env.dig(ACTIVE_RECORD_REQUEST_PARAMS, 'user', 'login') + +        return unless login.present? + +        user = User.by_login(login) + +        return unless user&.blocked? + +        Gitlab::AppLogger.info("Failed login for blocked user: user=#{user.username} ip=#{env['REMOTE_ADDR']}") +        SystemHooksService.new.execute_hooks_for(user, :failed_login) + +        true +      rescue TypeError +      end +    end +  end +end diff --git a/lib/gitlab/auth/user_auth_finders.rb b/lib/gitlab/auth/user_auth_finders.rb index b4114a3ac96..cf02030c577 100644 --- a/lib/gitlab/auth/user_auth_finders.rb +++ b/lib/gitlab/auth/user_auth_finders.rb @@ -96,9 +96,7 @@ module Gitlab        end        def ensure_action_dispatch_request(request) -        return request if request.is_a?(ActionDispatch::Request) - -        ActionDispatch::Request.new(request.env) +        ActionDispatch::Request.new(request.env.dup)        end        def current_request diff --git a/lib/gitlab/git/conflict/resolver.rb b/lib/gitlab/git/conflict/resolver.rb index 74c9874d590..07b7e811a34 100644 --- a/lib/gitlab/git/conflict/resolver.rb +++ b/lib/gitlab/git/conflict/resolver.rb @@ -15,7 +15,7 @@ module Gitlab            @conflicts ||= begin              @target_repository.gitaly_migrate(:conflicts_list_conflict_files) do |is_enabled|                if is_enabled -                gitaly_conflicts_client(@target_repository).list_conflict_files +                gitaly_conflicts_client(@target_repository).list_conflict_files.to_a                else                  rugged_list_conflict_files                end diff --git a/lib/gitlab/gitaly_client/conflict_files_stitcher.rb b/lib/gitlab/gitaly_client/conflict_files_stitcher.rb new file mode 100644 index 00000000000..97c13d1fdb0 --- /dev/null +++ b/lib/gitlab/gitaly_client/conflict_files_stitcher.rb @@ -0,0 +1,47 @@ +module Gitlab +  module GitalyClient +    class ConflictFilesStitcher +      include Enumerable + +      def initialize(rpc_response) +        @rpc_response = rpc_response +      end + +      def each +        current_file = nil + +        @rpc_response.each do |msg| +          msg.files.each do |gitaly_file| +            if gitaly_file.header +              yield current_file if current_file + +              current_file = file_from_gitaly_header(gitaly_file.header) +            else +              current_file.content << gitaly_file.content +            end +          end +        end + +        yield current_file if current_file +      end + +      private + +      def file_from_gitaly_header(header) +        Gitlab::Git::Conflict::File.new( +          Gitlab::GitalyClient::Util.git_repository(header.repository), +          header.commit_oid, +          conflict_from_gitaly_file_header(header), +          '' +        ) +      end + +      def conflict_from_gitaly_file_header(header) +        { +          ours: { path: header.our_path, mode: header.our_mode }, +          theirs: { path: header.their_path } +        } +      end +    end +  end +end diff --git a/lib/gitlab/gitaly_client/conflicts_service.rb b/lib/gitlab/gitaly_client/conflicts_service.rb index 40f032cf873..2565d537aff 100644 --- a/lib/gitlab/gitaly_client/conflicts_service.rb +++ b/lib/gitlab/gitaly_client/conflicts_service.rb @@ -20,7 +20,11 @@ module Gitlab          )          response = GitalyClient.call(@repository.storage, :conflicts_service, :list_conflict_files, request) -        files_from_response(response).to_a +        GitalyClient::ConflictFilesStitcher.new(response) +      end + +      def conflicts? +        list_conflict_files.any?        end        def resolve_conflicts(target_repository, resolution, source_branch, target_branch) @@ -58,38 +62,6 @@ module Gitlab            user: Gitlab::Git::User.from_gitlab(resolution.user).to_gitaly          )        end - -      def files_from_response(response) -        files = [] - -        response.each do |msg| -          msg.files.each do |gitaly_file| -            if gitaly_file.header -              files << file_from_gitaly_header(gitaly_file.header) -            else -              files.last.content << gitaly_file.content -            end -          end -        end - -        files -      end - -      def file_from_gitaly_header(header) -        Gitlab::Git::Conflict::File.new( -          Gitlab::GitalyClient::Util.git_repository(header.repository), -          header.commit_oid, -          conflict_from_gitaly_file_header(header), -          '' -        ) -      end - -      def conflict_from_gitaly_file_header(header) -        { -          ours: { path: header.our_path, mode: header.our_mode }, -          theirs: { path: header.their_path } -        } -      end      end    end  end | 
