rapid7/metasploit-framework

View on GitHub
tools/modules/module_rank.rb

Summary

Maintainability
A
25 mins
Test Coverage
#!/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