Sha256: 80d60261fd6df8fea9d484d9228fa266d24decdb55ed941486977af448c00757
Contents?: true
Size: 1.92 KB
Versions: 8
Compression:
Stored size: 1.92 KB
Contents
# frozen_string_literal: true module WPScan module Finders module Timthumbs # Known Locations Timthumbs Finder # Note: A vulnerable version, 2.8.13 can be found here: # https://github.com/GabrielGil/TimThumb/blob/980c3d6a823477761570475e8b83d3e9fcd2d7ae/timthumb.php class KnownLocations < CMSScanner::Finders::Finder include CMSScanner::Finders::Finder::Enumerator # @return [ Array<Integer> ] def valid_response_codes @valid_response_codes ||= [400] end # @param [ Hash ] opts # @option opts [ String ] :list Mandatory # # @return [ Array<Timthumb> ] def aggressive(opts = {}) found = [] enumerate(target_urls(opts), opts.merge(check_full_response: 400)) do |res| next unless res.body =~ /no image specified/i found << Model::Timthumb.new(res.request.url, opts.merge(found_by: found_by, confidence: 100)) end found end # @param [ Hash ] opts # @option opts [ String ] :list Mandatory # # @return [ Hash ] def target_urls(opts = {}) urls = {} File.open(opts[:list]).each_with_index do |path, index| urls[target.url(path.chomp)] = index end # Add potential timthumbs located in the main theme if target.main_theme main_theme_timthumbs_paths.each do |path| urls[target.main_theme.url(path)] = 1 # index not important there end end urls end def main_theme_timthumbs_paths %w[timthumb.php lib/timthumb.php inc/timthumb.php includes/timthumb.php scripts/timthumb.php tools/timthumb.php functions/timthumb.php] end def create_progress_bar(opts = {}) super(opts.merge(title: ' Checking Known Locations -')) end end end end end
Version data entries
8 entries across 8 versions & 1 rubygems