Sha256: 7976e2dcbbd87ff0344a46b10f3575a7fb7f407d4d2bfb7d5a312cff094a70d1

Contents?: true

Size: 1.95 KB

Versions: 8

Compression:

Stored size: 1.95 KB

Contents

# frozen_string_literal: true

module RuboCop
  module Cop
    module Bundler
      # The symbol argument `:gemcutter`, `:rubygems`, and `:rubyforge`
      # are deprecated. So please change your source to URL string that
      # 'https://rubygems.org' if possible, or 'http://rubygems.org' if not.
      #
      # This autocorrect will replace these symbols with 'https://rubygems.org'.
      # Because it is secure, HTTPS request is strongly recommended. And in
      # most use cases HTTPS will be fine.
      #
      # However, it don't replace all `sources` of `http://` with `https://`.
      # For example, when specifying an internal gem server using HTTP on the
      # intranet, a use case where HTTPS cannot be specified was considered.
      # Consider using HTTP only if you cannot use HTTPS.
      #
      # @example
      #   # bad
      #   source :gemcutter
      #   source :rubygems
      #   source :rubyforge
      #
      #   # good
      #   source 'https://rubygems.org' # strongly recommended
      #   source 'http://rubygems.org'
      class InsecureProtocolSource < Base
        include RangeHelp
        extend AutoCorrector

        MSG = 'The source `:%<source>s` is deprecated because HTTP requests ' \
              'are insecure. ' \
              "Please change your source to 'https://rubygems.org' " \
              "if possible, or 'http://rubygems.org' if not."

        def_node_matcher :insecure_protocol_source?, <<~PATTERN
          (send nil? :source
            $(sym ${:gemcutter :rubygems :rubyforge}))
        PATTERN

        def on_send(node)
          insecure_protocol_source?(node) do |source_node, source|
            message = format(MSG, source: source)

            add_offense(
              source_node,
              message: message
            ) do |corrector|
              corrector.replace(
                source_node, "'https://rubygems.org'"
              )
            end
          end
        end
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 3 rubygems

Version Path
grape-extra_validators-2.0.0 vendor/bundle/ruby/2.6.0/gems/rubocop-0.90.0/lib/rubocop/cop/bundler/insecure_protocol_source.rb
rubocop-0.90.0 lib/rubocop/cop/bundler/insecure_protocol_source.rb
rubocop-0.89.1 lib/rubocop/cop/bundler/insecure_protocol_source.rb
rubocop-0.89.0 lib/rubocop/cop/bundler/insecure_protocol_source.rb
rubocop-0.88.0 lib/rubocop/cop/bundler/insecure_protocol_source.rb
rbhint-0.87.1.rc1 lib/rubocop/cop/bundler/insecure_protocol_source.rb
rubocop-0.87.1 lib/rubocop/cop/bundler/insecure_protocol_source.rb
rubocop-0.87.0 lib/rubocop/cop/bundler/insecure_protocol_source.rb