123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132 |
- #!/usr/bin/env ruby
- ##
- # This module requires Metasploit: https://metasploit.com/download
- # Current source: https://github.com/rapid7/metasploit-framework
- ##
- #
- # This script lists each module with its rank
- #
- msfbase = __FILE__
- while File.symlink?(msfbase)
- msfbase = File.expand_path(File.readlink(msfbase), File.dirname(msfbase))
- end
- $:.unshift(File.expand_path(File.join(File.dirname(msfbase), '..', '..', 'lib')))
- require 'msfenv'
- $:.unshift(ENV['MSF_LOCAL_LIB']) if ENV['MSF_LOCAL_LIB']
- require 'rex'
- ranks= Hash.new
- ranks['Manual'] = 0
- ranks['Low'] = 100
- ranks['Average'] = 200
- ranks['Normal'] = 300
- ranks['Good'] = 400
- ranks['Great'] = 500
- ranks['Excellent'] = 600
- minrank= 0
- maxrank= 600
- sort = 0
- filter= 'All'
- filters = ['all','exploit','payload','post','nop','encoder','auxiliary']
- opts = Rex::Parser::Arguments.new(
- "-h" => [ false, "Help menu." ],
- "-M" => [ true, "Set Maximum Rank [Manual,Low,Average,Normal,Good,Great,Excellent] (Default = Excellent)." ],
- "-m" => [ true, "Set Minimum Rank [Manual,Low,Average,Normal,Good,Great,Excellent] (Default = Manual)."],
- "-s" => [ false, "Sort by Rank instead of Module Type."],
- "-r" => [ false, "Reverse Sort by Rank"],
- "-f" => [ true, "Filter based on Module Type [#{filters.map{|f|f.capitalize}.join(", ")}] (Default = All)."],
- )
- opts.parse(ARGV) { |opt, idx, val|
- case opt
- when "-h"
- puts "\nMetasploit Script for Displaying Module Rank information."
- puts "=========================================================="
- puts opts.usage
- exit
- when "-M"
- unless ranks.include?(val)
- puts "Invalid Rank Supplied: #{val}"
- puts "Please use one of these: [Manual,Low,Average,Normal,Good,Great,Excellent]"
- exit
- end
- puts "Maximum Rank: #{val}"
- maxrank = ranks[val]
- when "-m"
- unless ranks.include?(val)
- puts "Invalid Rank Supplied: #{val}"
- puts "Please use one of these: [Manual,Low,Average,Normal,Good,Great,Excellent]"
- exit
- end
- puts "Minimum Rank: #{val}"
- minrank = ranks[val]
- when "-s"
- puts "Sorting by Rank"
- sort = 1
- when "-r"
- puts "Reverse Sorting by Rank"
- sort = 2
- when "-f"
- unless filters.include?(val.downcase)
- puts "Invalid Filter Supplied: #{val}"
- puts "Please use one of these: #{filters.map{|f|f.capitalize}.join(", ")}"
- exit
- end
- puts "Module Filter: #{val}"
- filter = val
- end
- }
- Indent = ' '
- # Always disable the database (we never need it just to list module
- # information).
- framework_opts = { 'DisableDatabase' => true }
- # If the user only wants a particular module type, no need to load the others
- if filter.downcase != 'all'
- framework_opts[:module_types] = [ filter.downcase ]
- end
- # Initialize the simplified framework instance.
- $framework = Msf::Simple::Framework.create(framework_opts)
- tbl = Rex::Text::Table.new(
- 'Header' => 'Module Ranks',
- 'Indent' => Indent.length,
- 'Columns' => [ 'Module', 'Rank' ]
- )
- $framework.modules.each { |name, mod|
- x = mod.new
- modrank = x.rank
- if modrank >= minrank and modrank<= maxrank
- tbl << [ x.fullname, modrank ]
- end
- }
- if sort == 1
- tbl.sort_rows(1)
- end
- if sort == 2
- tbl.sort_rows(1)
- tbl.rows.reverse
- end
- puts tbl.to_s
|