diff options
| author | Rémy Coutable <remy@rymai.me> | 2017-08-16 11:25:26 +0000 | 
|---|---|---|
| committer | Rémy Coutable <remy@rymai.me> | 2017-08-16 11:25:26 +0000 | 
| commit | fcce6c3168dbd04404f318b4e983d7395d21538c (patch) | |
| tree | d8155d729f0915f6117bbe1f4010fffec9d37e56 /lib | |
| parent | 9ac2a517798af2f942b28138403690afc20a254c (diff) | |
| parent | 260c8da060a6039cbd47cfe31c8ec6d6f9b43de0 (diff) | |
| download | gitlab-ce-fcce6c3168dbd04404f318b4e983d7395d21538c.tar.gz | |
Merge branch 'rs-more-public-send-whitelists' into 'master'
Whitelist or fix additional `Gitlab/PublicSend` cop violations
See merge request !13467
Diffstat (limited to 'lib')
26 files changed, 39 insertions, 36 deletions
| diff --git a/lib/api/api_guard.rb b/lib/api/api_guard.rb index 0d2d71e336a..c4c0fdda665 100644 --- a/lib/api/api_guard.rb +++ b/lib/api/api_guard.rb @@ -122,7 +122,7 @@ module API          error_classes = [MissingTokenError, TokenNotFoundError,                           ExpiredError, RevokedError, InsufficientScopeError] -        base.send :rescue_from, *error_classes, oauth2_bearer_token_error_handler +        base.__send__(:rescue_from, *error_classes, oauth2_bearer_token_error_handler) # rubocop:disable GitlabSecurity/PublicSend        end        def oauth2_bearer_token_error_handler diff --git a/lib/api/entities.rb b/lib/api/entities.rb index 4219808fdc3..e8dd61e493f 100644 --- a/lib/api/entities.rb +++ b/lib/api/entities.rb @@ -541,8 +541,9 @@ module API          target_url    = "namespace_project_#{target_type}_url"          target_anchor = "note_#{todo.note_id}" if todo.note_id? -        Gitlab::Routing.url_helpers.public_send(target_url, -          todo.project.namespace, todo.project, todo.target, anchor: target_anchor) +        Gitlab::Routing +          .url_helpers +          .public_send(target_url, todo.project.namespace, todo.project, todo.target, anchor: target_anchor) # rubocop:disable GitlabSecurity/PublicSend        end        expose :body diff --git a/lib/api/runners.rb b/lib/api/runners.rb index 5bf5a18e42f..31f940fe96b 100644 --- a/lib/api/runners.rb +++ b/lib/api/runners.rb @@ -153,7 +153,7 @@ module API            render_api_error!('Scope contains invalid value', 400)          end -        runners.send(scope) +        runners.public_send(scope) # rubocop:disable GitlabSecurity/PublicSend        end        def get_runner(id) diff --git a/lib/api/v3/notes.rb b/lib/api/v3/notes.rb index 23fe95e42e4..d49772b92f2 100644 --- a/lib/api/v3/notes.rb +++ b/lib/api/v3/notes.rb @@ -22,7 +22,7 @@ module API              use :pagination            end            get ":id/#{noteables_str}/:noteable_id/notes" do -            noteable = user_project.send(noteables_str.to_sym).find(params[:noteable_id]) +            noteable = user_project.public_send(noteables_str.to_sym).find(params[:noteable_id]) # rubocop:disable GitlabSecurity/PublicSend              if can?(current_user, noteable_read_ability_name(noteable), noteable)                # We exclude notes that are cross-references and that cannot be viewed @@ -50,7 +50,7 @@ module API              requires :noteable_id, type: Integer, desc: 'The ID of the noteable'            end            get ":id/#{noteables_str}/:noteable_id/notes/:note_id" do -            noteable = user_project.send(noteables_str.to_sym).find(params[:noteable_id]) +            noteable = user_project.public_send(noteables_str.to_sym).find(params[:noteable_id]) # rubocop:disable GitlabSecurity/PublicSend              note = noteable.notes.find(params[:note_id])              can_read_note = can?(current_user, noteable_read_ability_name(noteable), noteable) && !note.cross_reference_not_visible_for?(current_user) @@ -76,7 +76,7 @@ module API                noteable_id: params[:noteable_id]              } -            noteable = user_project.send(noteables_str.to_sym).find(params[:noteable_id]) +            noteable = user_project.public_send(noteables_str.to_sym).find(params[:noteable_id]) # rubocop:disable GitlabSecurity/PublicSend              if can?(current_user, noteable_read_ability_name(noteable), noteable)                if params[:created_at] && (current_user.admin? || user_project.owner == current_user) diff --git a/lib/banzai/filter/external_issue_reference_filter.rb b/lib/banzai/filter/external_issue_reference_filter.rb index 53a229256a5..ed01a72ff9f 100644 --- a/lib/banzai/filter/external_issue_reference_filter.rb +++ b/lib/banzai/filter/external_issue_reference_filter.rb @@ -95,10 +95,10 @@ module Banzai        private        def external_issues_cached(attribute) -        return project.public_send(attribute) unless RequestStore.active? +        return project.public_send(attribute) unless RequestStore.active? # rubocop:disable GitlabSecurity/PublicSend          cached_attributes = RequestStore[:banzai_external_issues_tracker_attributes] ||= Hash.new { |h, k| h[k] = {} } -        cached_attributes[project.id][attribute] = project.public_send(attribute) if cached_attributes[project.id][attribute].nil? +        cached_attributes[project.id][attribute] = project.public_send(attribute) if cached_attributes[project.id][attribute].nil? # rubocop:disable GitlabSecurity/PublicSend          cached_attributes[project.id][attribute]        end      end diff --git a/lib/banzai/object_renderer.rb b/lib/banzai/object_renderer.rb index 002a3341ccd..2196a92474c 100644 --- a/lib/banzai/object_renderer.rb +++ b/lib/banzai/object_renderer.rb @@ -37,7 +37,7 @@ module Banzai        objects.each_with_index do |object, index|          redacted_data = redacted[index] -        object.__send__("redacted_#{attribute}_html=", redacted_data[:document].to_html.html_safe) +        object.__send__("redacted_#{attribute}_html=", redacted_data[:document].to_html.html_safe) # rubocop:disable GitlabSecurity/PublicSend          object.user_visible_reference_count = redacted_data[:visible_reference_count]        end      end diff --git a/lib/banzai/pipeline/base_pipeline.rb b/lib/banzai/pipeline/base_pipeline.rb index 321fd5bbe14..3ae3bed570d 100644 --- a/lib/banzai/pipeline/base_pipeline.rb +++ b/lib/banzai/pipeline/base_pipeline.rb @@ -18,7 +18,7 @@ module Banzai            define_method(meth) do |text, context|              context = transform_context(context) -            html_pipeline.send(meth, text, context) +            html_pipeline.__send__(meth, text, context) # rubocop:disable GitlabSecurity/PublicSend            end          end        end diff --git a/lib/banzai/renderer.rb b/lib/banzai/renderer.rb index ad08c0905e2..95d82d17658 100644 --- a/lib/banzai/renderer.rb +++ b/lib/banzai/renderer.rb @@ -43,7 +43,7 @@ module Banzai      # Same as +render_field+, but without consulting or updating the cache field      def self.cacheless_render_field(object, field, options = {}) -      text = object.__send__(field) +      text = object.__send__(field) # rubocop:disable GitlabSecurity/PublicSend        context = object.banzai_render_context(field).merge(options)        cacheless_render(text, context) @@ -156,7 +156,7 @@ module Banzai      # method.      def self.full_cache_multi_key(cache_key, pipeline_name)        return unless cache_key -      Rails.cache.send(:expanded_key, full_cache_key(cache_key, pipeline_name)) +      Rails.cache.__send__(:expanded_key, full_cache_key(cache_key, pipeline_name)) # rubocop:disable GitlabSecurity/PublicSend      end      # GitLab EE needs to disable updates on GET requests in Geo diff --git a/lib/bitbucket/collection.rb b/lib/bitbucket/collection.rb index 3a9379ff680..a78495dbf5e 100644 --- a/lib/bitbucket/collection.rb +++ b/lib/bitbucket/collection.rb @@ -13,7 +13,7 @@ module Bitbucket      def method_missing(method, *args)        return super unless self.respond_to?(method) -      self.send(method, *args) do |item| +      self.__send__(method, *args) do |item| # rubocop:disable GitlabSecurity/PublicSend          block_given? ? yield(item) : item        end      end diff --git a/lib/ci/ansi2html.rb b/lib/ci/ansi2html.rb index 8354fc8d595..b9e9f9f7f4a 100644 --- a/lib/ci/ansi2html.rb +++ b/lib/ci/ansi2html.rb @@ -208,7 +208,7 @@ module Ci          return unless command = stack.shift()          if self.respond_to?("on_#{command}", true) -          self.send("on_#{command}", stack) +          self.__send__("on_#{command}", stack) # rubocop:disable GitlabSecurity/PublicSend          end          evaluate_command_stack(stack) diff --git a/lib/declarative_policy/base.rb b/lib/declarative_policy/base.rb index f39b5bf29ec..b028169f500 100644 --- a/lib/declarative_policy/base.rb +++ b/lib/declarative_policy/base.rb @@ -109,7 +109,7 @@ module DeclarativePolicy          name = name.to_sym          if delegation_block.nil? -          delegation_block = proc { @subject.__send__(name) } +          delegation_block = proc { @subject.__send__(name) } # rubocop:disable GitlabSecurity/PublicSend          end          own_delegations[name] = delegation_block diff --git a/lib/declarative_policy/dsl.rb b/lib/declarative_policy/dsl.rb index b26807a7622..6ba1e7a3c5c 100644 --- a/lib/declarative_policy/dsl.rb +++ b/lib/declarative_policy/dsl.rb @@ -93,7 +93,7 @@ module DeclarativePolicy      def method_missing(m, *a, &b)        return super unless @context_class.respond_to?(m) -      @context_class.__send__(m, *a, &b) +      @context_class.__send__(m, *a, &b) # rubocop:disable GitlabSecurity/PublicSend      end      def respond_to_missing?(m) diff --git a/lib/file_size_validator.rb b/lib/file_size_validator.rb index eb19ab45ac3..de391de9059 100644 --- a/lib/file_size_validator.rb +++ b/lib/file_size_validator.rb @@ -44,13 +44,13 @@ class FileSizeValidator < ActiveModel::EachValidator          when Integer            check_value          when Symbol -          record.send(check_value) +          record.public_send(check_value) # rubocop:disable GitlabSecurity/PublicSend          end        value ||= [] if key == :maximum        value_size = value.size -      next if value_size.send(validity_check, check_value) +      next if value_size.public_send(validity_check, check_value) # rubocop:disable GitlabSecurity/PublicSend        errors_options = options.except(*RESERVED_OPTIONS)        errors_options[:file_size] = help.number_to_human_size check_value diff --git a/lib/gitlab/auth.rb b/lib/gitlab/auth.rb index 7d3aa532750..8cb4060cd97 100644 --- a/lib/gitlab/auth.rb +++ b/lib/gitlab/auth.rb @@ -101,7 +101,7 @@ module Gitlab          if Service.available_services_names.include?(underscored_service)            # We treat underscored_service as a trusted input because it is included            # in the Service.available_services_names whitelist. -          service = project.public_send("#{underscored_service}_service") +          service = project.public_send("#{underscored_service}_service") # rubocop:disable GitlabSecurity/PublicSend            if service && service.activated? && service.valid_token?(password)              Gitlab::Auth::Result.new(nil, project, :ci, build_authentication_abilities) @@ -149,7 +149,7 @@ module Gitlab        def abilities_for_scope(scopes)          scopes.map do |scope| -          self.public_send(:"#{scope}_scope_authentication_abilities") +          self.public_send(:"#{scope}_scope_authentication_abilities") # rubocop:disable GitlabSecurity/PublicSend          end.flatten.uniq        end diff --git a/lib/gitlab/cache/request_cache.rb b/lib/gitlab/cache/request_cache.rb index f1a04affd38..754a45c3257 100644 --- a/lib/gitlab/cache/request_cache.rb +++ b/lib/gitlab/cache/request_cache.rb @@ -69,7 +69,7 @@ module Gitlab                    instance_variable_set(ivar_name, {})                end -            key = __send__(cache_key_method_name, args) +            key = __send__(cache_key_method_name, args) # rubocop:disable GitlabSecurity/PublicSend              store.fetch(key) { store[key] = super(*args) }            end diff --git a/lib/gitlab/diff/line_mapper.rb b/lib/gitlab/diff/line_mapper.rb index 576a761423e..cf71d47df8e 100644 --- a/lib/gitlab/diff/line_mapper.rb +++ b/lib/gitlab/diff/line_mapper.rb @@ -38,7 +38,7 @@ module Gitlab          # - The first diff line with a higher line number, if it falls between diff contexts          # - The last known diff line, if it falls after the last diff context          diff_line = diff_lines.find do |diff_line| -          diff_from_line = diff_line.send(from) +          diff_from_line = diff_line.public_send(from) # rubocop:disable GitlabSecurity/PublicSend            diff_from_line && diff_from_line >= from_line          end          diff_line ||= diff_lines.last @@ -47,8 +47,8 @@ module Gitlab          # mapped line number is the same as the specified line number.          return from_line unless diff_line -        diff_from_line = diff_line.send(from) -        diff_to_line = diff_line.send(to) +        diff_from_line = diff_line.public_send(from) # rubocop:disable GitlabSecurity/PublicSend +        diff_to_line = diff_line.public_send(to) # rubocop:disable GitlabSecurity/PublicSend          # If the line was removed, there is no mapped line number.          return unless diff_to_line diff --git a/lib/gitlab/git/blob.rb b/lib/gitlab/git/blob.rb index 28835d7f5d2..7780f4e4d4f 100644 --- a/lib/gitlab/git/blob.rb +++ b/lib/gitlab/git/blob.rb @@ -173,7 +173,7 @@ module Gitlab        def initialize(options)          %w(id name path size data mode commit_id binary).each do |key| -          self.send("#{key}=", options[key.to_sym]) +          self.__send__("#{key}=", options[key.to_sym]) # rubocop:disable GitlabSecurity/PublicSend          end          @loaded_all_data = false diff --git a/lib/gitlab/git/tree.rb b/lib/gitlab/git/tree.rb index 8e959c57c7c..b54962a4456 100644 --- a/lib/gitlab/git/tree.rb +++ b/lib/gitlab/git/tree.rb @@ -89,7 +89,7 @@ module Gitlab        def initialize(options)          %w(id root_id name path type mode commit_id).each do |key| -          self.send("#{key}=", options[key.to_sym]) +          self.send("#{key}=", options[key.to_sym]) # rubocop:disable GitlabSecurity/PublicSend          end        end diff --git a/lib/gitlab/gitaly_client.rb b/lib/gitlab/gitaly_client.rb index 70177cd0fec..9a5f4f598b2 100644 --- a/lib/gitlab/gitaly_client.rb +++ b/lib/gitlab/gitaly_client.rb @@ -55,7 +55,7 @@ module Gitlab      def self.call(storage, service, rpc, request)        metadata = request_metadata(storage)        metadata = yield(metadata) if block_given? -      stub(service, storage).send(rpc, request, metadata) +      stub(service, storage).__send__(rpc, request, metadata) # rubocop:disable GitlabSecurity/PublicSend      end      def self.request_metadata(storage) diff --git a/lib/gitlab/github_import/base_formatter.rb b/lib/gitlab/github_import/base_formatter.rb index 8c80791e7c9..f330041cc00 100644 --- a/lib/gitlab/github_import/base_formatter.rb +++ b/lib/gitlab/github_import/base_formatter.rb @@ -11,7 +11,9 @@ module Gitlab        end        def create! -        project.public_send(project_association).find_or_create_by!(find_condition) do |record| +        association = project.public_send(project_association) # rubocop:disable GitlabSecurity/PublicSend + +        association.find_or_create_by!(find_condition) do |record|            record.attributes = attributes          end        end diff --git a/lib/gitlab/github_import/client.rb b/lib/gitlab/github_import/client.rb index 7dbeec5b010..0550f9695bd 100644 --- a/lib/gitlab/github_import/client.rb +++ b/lib/gitlab/github_import/client.rb @@ -120,7 +120,7 @@ module Gitlab        def request(method, *args, &block)          sleep rate_limit_sleep_time if rate_limit_exceed? -        data = api.send(method, *args) +        data = api.__send__(method, *args) # rubocop:disable GitlabSecurity/PublicSend          return data unless data.is_a?(Array)          last_response = api.last_response diff --git a/lib/gitlab/github_import/importer.rb b/lib/gitlab/github_import/importer.rb index 266b1a6fece..373062b354b 100644 --- a/lib/gitlab/github_import/importer.rb +++ b/lib/gitlab/github_import/importer.rb @@ -289,7 +289,7 @@ module Gitlab          opts.last[:page] = current_page(resource_type) -        client.public_send(resource_type, *opts) do |resources| +        client.public_send(resource_type, *opts) do |resources| # rubocop:disable GitlabSecurity/PublicSend            yield resources            increment_page(resource_type)          end diff --git a/lib/gitlab/lazy.rb b/lib/gitlab/lazy.rb index 2a659ae4c74..99594577141 100644 --- a/lib/gitlab/lazy.rb +++ b/lib/gitlab/lazy.rb @@ -16,7 +16,7 @@ module Gitlab      def method_missing(name, *args, &block)        __evaluate__ -      @result.__send__(name, *args, &block) +      @result.__send__(name, *args, &block) # rubocop:disable GitlabSecurity/PublicSend      end      def respond_to_missing?(name, include_private = false) diff --git a/lib/gitlab/ldap/person.rb b/lib/gitlab/ldap/person.rb index 43eb73250b7..e138b466a34 100644 --- a/lib/gitlab/ldap/person.rb +++ b/lib/gitlab/ldap/person.rb @@ -32,7 +32,7 @@ module Gitlab        end        def uid -        entry.send(config.uid).first +        entry.public_send(config.uid).first # rubocop:disable GitlabSecurity/PublicSend        end        def username @@ -65,7 +65,7 @@ module Gitlab          return nil unless selected_attr -        entry.public_send(selected_attr) +        entry.public_send(selected_attr) # rubocop:disable GitlabSecurity/PublicSend        end      end    end diff --git a/lib/gitlab/markdown/pipeline.rb b/lib/gitlab/markdown/pipeline.rb index 699d8b9fc07..306923902e0 100644 --- a/lib/gitlab/markdown/pipeline.rb +++ b/lib/gitlab/markdown/pipeline.rb @@ -23,7 +23,7 @@ module Gitlab            define_method(meth) do |text, context|              context = transform_context(context) -            html_pipeline.send(meth, text, context) +            html_pipeline.__send__(meth, text, context) # rubocop:disable GitlabSecurity/PublicSend            end          end        end diff --git a/lib/uploaded_file.rb b/lib/uploaded_file.rb index 41dee5fdc06..4a3c40f88eb 100644 --- a/lib/uploaded_file.rb +++ b/lib/uploaded_file.rb @@ -27,7 +27,7 @@ class UploadedFile    alias_method :local_path, :path    def method_missing(method_name, *args, &block) #:nodoc: -    @tempfile.__send__(method_name, *args, &block) +    @tempfile.__send__(method_name, *args, &block) # rubocop:disable GitlabSecurity/PublicSend    end    def respond_to?(method_name, include_private = false) #:nodoc: | 
