Sha256: 68f7396db4b1a675aa817a664ffb8d6fe624f52dbf46eb0a5c4b58564e4f2836

Contents?: true

Size: 1.92 KB

Versions: 44

Compression:

Stored size: 1.92 KB

Contents

# frozen_string_literal: true

module WPScan
  module Finders
    module DynamicFinder
      module Version
        # Version finder using JavaScript Variable method
        class JavascriptVar < Finders::DynamicFinder::Version::Finder
          # @return [ Hash ]
          def self.child_class_constants
            @child_class_constants ||= super().merge(
              XPATH: '//script[not(@src)]', VERSION_KEY: nil,
              PATTERN: nil, CONFIDENCE: 60
            )
          end

          # @param [ Typhoeus::Response ] response
          # @param [ Hash ] opts
          # @return [ Version ]
          def find(response, _opts = {})
            target.xpath_pattern_from_page(
              self.class::XPATH, self.class::PATTERN, response
            ) do |match_data, _node|
              next unless (version_number = version_number_from_match_data(match_data))

              # If the text to be output in the interesting_entries is > 50 chars,
              # get 20 chars before and after (when possible) the detected version instead
              match = match_data.to_s
              match = match[/.*?(.{,20}#{Regexp.escape(version_number)}.{,20}).*/, 1] if match.size > 50

              return create_version(
                version_number,
                interesting_entries: ["#{response.effective_url}, Match: '#{match.strip}'"]
              )
            end
            nil
          end

          # @param [ MatchData ] match_data
          # @return [ String ]
          def version_number_from_match_data(match_data)
            if self.class::VERSION_KEY
              begin
                json = JSON.parse("{#{match_data[:json].strip.chomp(',').tr("'", '"')}}")
              rescue JSON::ParserError
                return
              end

              json.dig(*self.class::VERSION_KEY.split(':'))
            else
              match_data[:v]
            end
          end
        end
      end
    end
  end
end

Version data entries

44 entries across 44 versions & 1 rubygems

Version Path
wpscan-3.8.27 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.26 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.25 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.24 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.22 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.21 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.20 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.19 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.18 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.17 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.16 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.15 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.14 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.13 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.12 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.11 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.10 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.9 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.8 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb
wpscan-3.8.7 lib/wpscan/finders/dynamic_finder/version/javascript_var.rb