Sha256: 77168aa9b14fd98b3083de9e9fd4fbe69adf1c841b9434b81651fde44c8c4b7a

Contents?: true

Size: 1.57 KB

Versions: 10

Compression:

Stored size: 1.57 KB

Contents

# frozen_string_literal: true

module WPScan
  module DB
    module DynamicFinders
      class Base
        # @return [ String ]
        def self.df_file
          @df_file ||= DB_DIR.join('dynamic_finders.yml').to_s
        end

        # @return [ Hash ]
        def self.all_df_data
          @all_df_data ||= if Gem::Version.new(Psych::VERSION) >= Gem::Version.new('4.0.0')
                             YAML.safe_load(File.read(df_file), permitted_classes: [Regexp])
                           else
                             YAML.safe_load(File.read(df_file), [Regexp])
                           end
        end

        # @return [ Array<Symbol> ]
        def self.allowed_classes
          # The Readme is not put in there as it's not a Real DF, but rather using the DF system
          # to get the list of potential filenames for a given slug
          @allowed_classes ||= %i[Comment Xpath HeaderPattern BodyPattern JavascriptVar QueryParameter ConfigParser]
        end

        # @param [ Symbol ] sym
        def self.method_missing(sym)
          super unless sym =~ /\A(passive|aggressive)_(.*)_finder_configs\z/i

          finder_class = Regexp.last_match[2].camelize.to_sym

          raise "#{finder_class} is not allowed as a Dynamic Finder" unless allowed_classes.include?(finder_class)

          finder_configs(
            finder_class,
            aggressive: Regexp.last_match[1] == 'aggressive'
          )
        end

        def self.respond_to_missing?(sym, *_args)
          sym =~ /\A(passive|aggressive)_(.*)_finder_configs\z/i
        end
      end
    end
  end
end

Version data entries

10 entries across 10 versions & 1 rubygems

Version Path
wpscan-3.8.28 lib/wpscan/db/dynamic_finders/base.rb
wpscan-3.8.27 lib/wpscan/db/dynamic_finders/base.rb
wpscan-3.8.26 lib/wpscan/db/dynamic_finders/base.rb
wpscan-3.8.25 lib/wpscan/db/dynamic_finders/base.rb
wpscan-3.8.24 lib/wpscan/db/dynamic_finders/base.rb
wpscan-3.8.22 lib/wpscan/db/dynamic_finders/base.rb
wpscan-3.8.21 lib/wpscan/db/dynamic_finders/base.rb
wpscan-3.8.20 lib/wpscan/db/dynamic_finders/base.rb
wpscan-3.8.19 lib/wpscan/db/dynamic_finders/base.rb
wpscan-3.8.18 lib/wpscan/db/dynamic_finders/base.rb