metasploit-framework/modules/auxiliary/server/tftp.rb

92 lines
2.3 KiB
Ruby
Raw Normal View History

##
# This module requires Metasploit: http//metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework
##
require 'msf/core'
require 'rex/proto/tftp'
require 'tmpdir'
class Metasploit3 < Msf::Auxiliary
2013-08-30 21:28:54 +00:00
include Msf::Exploit::Remote::TFTPServer
include Msf::Auxiliary::Report
2013-08-30 21:28:54 +00:00
def initialize
super(
'Name' => 'TFTP File Server',
'Description' => %q{
This module provides a TFTP service
},
'Author' => [ 'jduck', 'todb' ],
2013-08-30 21:28:54 +00:00
'License' => MSF_LICENSE,
'Actions' =>
[
[ 'Service' ]
],
'PassiveActions' =>
[
'Service'
],
'DefaultAction' => 'Service'
)
2013-08-30 21:28:54 +00:00
register_options(
[
OptAddress.new('SRVHOST', [ true, "The local host to listen on.", '0.0.0.0' ]),
OptPort.new('SRVPORT', [ true, "The local port to listen on.", 69 ]),
OptString.new('TFTPROOT', [ true, "The TFTP root directory to serve files from", Dir.tmpdir ]),
OptString.new('OUTPUTPATH', [ true, "The directory in which uploaded files will be written.", Dir.tmpdir ])
2013-08-30 21:28:54 +00:00
], self.class)
end
def srvhost
datastore['SRVHOST'] || '0.0.0.0'
end
def srvport
datastore['SRVPORT'] || 69
end
2013-08-30 21:28:54 +00:00
def run
if datastore['OUTPUTPATH'] and datastore['TFTPROOT']
print_status("Starting TFTP server on #{srvhost}:#{srvport}...")
else
2013-08-30 21:28:54 +00:00
print_error("You must set TFTPROOT and/or OUTPUTPATH to use this module.")
return
end
@tftp = Rex::Proto::TFTP::Server.new(
srvport,
srvhost,
{}
)
2013-08-30 21:28:54 +00:00
if datastore['TFTPROOT']
print_status("Files will be served from #{datastore['TFTPROOT']}")
@tftp.set_tftproot(datastore['TFTPROOT'])
end
2013-08-30 21:28:54 +00:00
# register output directory
if datastore['OUTPUTPATH']
print_status("Uploaded files will be saved in #{datastore['OUTPUTPATH']}")
@tftp.set_output_dir(datastore['OUTPUTPATH'])
end
2013-08-30 21:28:54 +00:00
# Individual virtual files can be served here -
#@tftp.register_file("ays", "A" * 2048) # multiple of 512 on purpose
2013-08-30 21:28:54 +00:00
@tftp.start
add_socket(@tftp.sock)
2013-08-30 21:28:54 +00:00
# Wait for finish..
while @tftp.thread.alive?
select(nil, nil, nil, 2)
end
2013-08-30 21:28:54 +00:00
vprint_status("Stopping TFTP server")
@tftp.stop
end
end