set_file_owner.py 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. fname=r'h:\tmp.txt'
  2. import win32security,win32file,win32api,ntsecuritycon,win32con
  3. new_privs = ((win32security.LookupPrivilegeValue('',ntsecuritycon.SE_SECURITY_NAME),win32con.SE_PRIVILEGE_ENABLED),
  4. (win32security.LookupPrivilegeValue('',ntsecuritycon.SE_SHUTDOWN_NAME),win32con.SE_PRIVILEGE_ENABLED),
  5. (win32security.LookupPrivilegeValue('',ntsecuritycon.SE_TCB_NAME),win32con.SE_PRIVILEGE_ENABLED),
  6. (win32security.LookupPrivilegeValue('',ntsecuritycon.SE_RESTORE_NAME),win32con.SE_PRIVILEGE_ENABLED),
  7. (win32security.LookupPrivilegeValue('',ntsecuritycon.SE_TAKE_OWNERSHIP_NAME),win32con.SE_PRIVILEGE_ENABLED),
  8. (win32security.LookupPrivilegeValue('',ntsecuritycon.SE_CREATE_PERMANENT_NAME),win32con.SE_PRIVILEGE_ENABLED),
  9. (win32security.LookupPrivilegeValue('','SeEnableDelegationPrivilege'),win32con.SE_PRIVILEGE_ENABLED) ##doesn't seem to be in ntsecuritycon.py ?
  10. )
  11. ph = win32api.GetCurrentProcess()
  12. th = win32security.OpenProcessToken(ph,win32security.TOKEN_ALL_ACCESS|win32con.TOKEN_ADJUST_PRIVILEGES)
  13. win32security.AdjustTokenPrivileges(th,0,new_privs)
  14. all_security_info = \
  15. win32security.OWNER_SECURITY_INFORMATION|win32security.GROUP_SECURITY_INFORMATION| \
  16. win32security.DACL_SECURITY_INFORMATION|win32security.SACL_SECURITY_INFORMATION
  17. sd=win32security.GetFileSecurity(fname,all_security_info)
  18. old_dacl=sd.GetSecurityDescriptorDacl()
  19. old_sacl=sd.GetSecurityDescriptorSacl()
  20. old_group=sd.GetSecurityDescriptorGroup()
  21. new_sd=win32security.SECURITY_DESCRIPTOR()
  22. print "relative, valid, size: ",new_sd.IsSelfRelative(), new_sd.IsValid(), new_sd.GetLength()
  23. my_sid = win32security.GetTokenInformation(th,ntsecuritycon.TokenUser)[0]
  24. tmp_sid = win32security.LookupAccountName('','tmp')[0]
  25. new_sd.SetSecurityDescriptorSacl(1,old_sacl,1)
  26. new_sd.SetSecurityDescriptorDacl(1,old_dacl,1)
  27. new_sd.SetSecurityDescriptorOwner(tmp_sid,0)
  28. new_sd.SetSecurityDescriptorGroup(old_group,0)
  29. win32security.SetFileSecurity(fname,all_security_info,new_sd)