32 lines
1.4 KiB
Python
32 lines
1.4 KiB
Python
|
import win32security,win32file,win32api,ntsecuritycon,win32con
|
||
|
from security_enums import TRUSTEE_TYPE,TRUSTEE_FORM,ACE_FLAGS,ACCESS_MODE
|
||
|
|
||
|
new_privs = ((win32security.LookupPrivilegeValue('',ntsecuritycon.SE_SECURITY_NAME),win32con.SE_PRIVILEGE_ENABLED),
|
||
|
(win32security.LookupPrivilegeValue('',ntsecuritycon.SE_CREATE_PERMANENT_NAME),win32con.SE_PRIVILEGE_ENABLED),
|
||
|
(win32security.LookupPrivilegeValue('','SeEnableDelegationPrivilege'),win32con.SE_PRIVILEGE_ENABLED) ##doesn't seem to be in ntsecuritycon.py ?
|
||
|
)
|
||
|
|
||
|
ph = win32api.GetCurrentProcess()
|
||
|
th = win32security.OpenProcessToken(ph,win32security.TOKEN_ALL_ACCESS) ##win32con.TOKEN_ADJUST_PRIVILEGES)
|
||
|
win32security.AdjustTokenPrivileges(th,0,new_privs)
|
||
|
|
||
|
policy_handle = win32security.GetPolicyHandle('',win32security.POLICY_ALL_ACCESS)
|
||
|
tmp_sid = win32security.LookupAccountName('','tmp')[0]
|
||
|
|
||
|
privs=[ntsecuritycon.SE_DEBUG_NAME,ntsecuritycon.SE_TCB_NAME,ntsecuritycon.SE_RESTORE_NAME,ntsecuritycon.SE_REMOTE_SHUTDOWN_NAME]
|
||
|
win32security.LsaAddAccountRights(policy_handle,tmp_sid,privs)
|
||
|
|
||
|
privlist=win32security.LsaEnumerateAccountRights(policy_handle,tmp_sid)
|
||
|
for priv in privlist:
|
||
|
print(priv)
|
||
|
|
||
|
privs=[ntsecuritycon.SE_DEBUG_NAME,ntsecuritycon.SE_TCB_NAME]
|
||
|
win32security.LsaRemoveAccountRights(policy_handle,tmp_sid,0,privs)
|
||
|
|
||
|
privlist=win32security.LsaEnumerateAccountRights(policy_handle,tmp_sid)
|
||
|
for priv in privlist:
|
||
|
print(priv)
|
||
|
|
||
|
win32security.LsaClose(policy_handle)
|
||
|
|