Juan changes applied

bug/bundler_fix
bmerinofe 2013-08-28 19:53:54 +02:00
parent 2b577552a2
commit c31a2332be
1 changed files with 40 additions and 15 deletions

View File

@ -29,6 +29,7 @@ class Metasploit3 < Msf::Post
OptAddress.new('CADDRESS', [ true, 'IPv4/IPv6 address to which to connect.']), OptAddress.new('CADDRESS', [ true, 'IPv4/IPv6 address to which to connect.']),
OptInt.new( 'CPORT', [ true, 'Port number to which to connect.']), OptInt.new( 'CPORT', [ true, 'Port number to which to connect.']),
OptInt.new( 'LPORT', [ true, 'Port number to which to listen.']), OptInt.new( 'LPORT', [ true, 'Port number to which to listen.']),
OptBool.new( 'IPV6_XP', [ true, 'Install IPv6 on Windows XP (needed for v4tov4).', true]),
OptEnum.new( 'TYPE', [ true, 'Type of forwarding', 'v4tov4', ['v4tov4','v6tov6','v6tov4','v4tov6']]) OptEnum.new( 'TYPE', [ true, 'Type of forwarding', 'v4tov4', ['v4tov4','v6tov6','v6tov4','v4tov6']])
], self.class) ], self.class)
end end
@ -42,19 +43,26 @@ class Metasploit3 < Msf::Post
type = datastore['TYPE'] type = datastore['TYPE']
lport = datastore['LPORT'] lport = datastore['LPORT']
cport = datastore['CPORT'] cport = datastore['CPORT']
ipv6_xp = datastore['IPV6_XP']
laddress = datastore['LADDRESS'] laddress = datastore['LADDRESS']
caddress = datastore['CADDRESS'] caddress = datastore['CADDRESS']
return if not enable_portproxy(lport,cport,laddress,caddress,type) return if not enable_portproxy(lport,cport,laddress,caddress,type,ipv6_xp)
fw_enable_ports(lport) fw_enable_ports(lport)
end end
def enable_portproxy(lport,cport,laddress,caddress,type) def enable_portproxy(lport,cport,laddress,caddress,type,ipv6_xp)
# Due to a bug in Windows XP you need to install ipv6 rtable = Rex::Ui::Text::Table.new(
'Header' => 'Port Forwarding Table',
'Indent' => 3,
'Columns' => ['LOCAL IP', 'LOCAL PORT', 'REMOTE IP', 'REMOTE PORT']
)
# Due to a bug in Windows XP you need to install IPv6
# http://support.microsoft.com/kb/555744/en-us # http://support.microsoft.com/kb/555744/en-us
if sysinfo["OS"] =~ /XP/ if sysinfo["OS"] =~ /XP/
return false if not enable_ipv6() return false if not check_ipv6(ipv6_xp)
end end
print_status("Setting PortProxy ...") print_status("Setting PortProxy ...")
@ -67,26 +75,43 @@ class Metasploit3 < Msf::Post
end end
output = cmd_exec("netsh","interface portproxy show all") output = cmd_exec("netsh","interface portproxy show all")
print_status("Local IP\tLocal Port\tRemote IP\tRemote Port")
output.each_line do |l| output.each_line do |l|
print_status("#{l.chomp}") if l.strip =~ /^[0-9]|\*/ rtable << l.split(" ") if l.strip =~ /^[0-9]|\*/
end end
print_status(rtable.to_s)
return true return true
end end
def enable_ipv6() def ipv6_installed()
print_status("Checking IPv6. This could take a while ...") output = cmd_exec("netsh","interface ipv6 show interface")
cmd_exec("netsh","interface ipv6 install",120) if output.lines.count > 2
output = cmd_exec("netsh","interface ipv6 show global")
if output =~ /-----/
print_good("IPV6 installed.")
return true return true
else else
print_error("IPv6 was not successfully installed. Run it again.")
return false return false
end end
end end
def check_ipv6(ipv6_xp)
if ipv6_installed()
print_status("IPv6 is already installed.")
return true
else
if not ipv6_xp
print_error("IPv6 is not installed. You need IPv6 to use portproxy.")
return false
else
print_status("Installing IPv6 ...")
cmd_exec("netsh","interface ipv6 install",120)
if not ipv6_installed
print_error("IPv6 was not successfully installed. Run it again.")
return false
end
print_good("IPv6 was successfully installed.")
return true
end
end
end
def fw_enable_ports(port) def fw_enable_ports(port)
print_status ("Setting port #{port} in Windows Firewall ...") print_status ("Setting port #{port} in Windows Firewall ...")
begin begin
@ -102,8 +127,8 @@ class Metasploit3 < Msf::Post
else else
print_error("There was an error enabling the port.") print_error("There was an error enabling the port.")
end end
rescue::Exception => e rescue ::Exception => e
print_status("The following Error was encountered: #{e.class} #{e}") print_status("The following Error was encountered: #{e.class} #{e}")
end end
end end
end end