Sha256: 2f99c6e0553270b8956184633e27bfd281181524c06d3e5dd1ab6c3e84a2fbed

Contents?: true

Size: 1.95 KB

Versions: 17

Compression:

Stored size: 1.95 KB

Contents

# frozen_string_literal: true

module WPScan
  module Finders
    module DynamicFinder
      module Version
        # Version finder using by parsing config files, such as composer.json
        # and so on
        class ConfigParser < Finders::DynamicFinder::Version::Finder
          ALLOWED_PARSERS = [JSON, YAML].freeze

          def self.child_class_constants
            @child_class_constants ||= super.merge(
              PARSER: nil, KEY: nil, PATTERN: /(?<v>\d+\.[\.\d]+)/, CONFIDENCE: 70
            )
          end

          # @param [ String ] body
          # @return [ Hash, nil ] The parsed body, with an available parser, if possible
          def parse(body)
            parsers = ALLOWED_PARSERS.include?(self.class::PARSER) ? [self.class::PARSER] : ALLOWED_PARSERS

            parsers.each do |parser|
              begin
                parsed = parser.respond_to?(:safe_load) ? parser.safe_load(body) : parser.load(body)

                return parsed if parsed.is_a?(Hash) || parsed.is_a?(Array)
              rescue StandardError
                next
              end
            end

            nil # Make sure nil is returned in case none of the parsers managed to parse the body correctly
          end

          # No Passive way
          def passive(opts = {}); end

          # @param [ Typhoeus::Response ] response
          # @param [ Hash ] opts
          # @return [ Version ]
          def find(response, _opts = {})
            parsed_body = parse(response.body)
            # Create indexes for the #dig, digits are converted to integers
            indexes     = self.class::KEY.split(':').map { |e| e == e.to_i.to_s ? e.to_i : e }

            return unless (data = parsed_body&.dig(*indexes)) && data =~ self.class::PATTERN

            create_version(
              Regexp.last_match[:v],
              interesting_entries: ["#{response.effective_url}, Match: '#{Regexp.last_match}'"]
            )
          end
        end
      end
    end
  end
end

Version data entries

17 entries across 17 versions & 1 rubygems

Version Path
wpscan-3.7.11 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.7.10 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.7.9 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.7.8 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.7.7 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.7.6 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.7.5 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.7.4 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.7.3 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.7.2 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.7.1 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.7.0 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.6.3 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.6.2 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.6.1 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.6.0 lib/wpscan/finders/dynamic_finder/version/config_parser.rb
wpscan-3.5.5 lib/wpscan/finders/dynamic_finder/version/config_parser.rb