Advertisement
St1cky

Disabling_SelectiveSuspended.ps1

Mar 9th, 2021
1,882
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. $ErrorActionPreference= 'silentlycontinue'
  2.  
  3. Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy Unrestricted -Force
  4.  
  5. function Take-Permissions {
  6.     # Developed for PowerShell v4.0
  7.     # Required Admin privileges
  8.     # Links:
  9.     #   http://shrekpoint.blogspot.ru/2012/08/taking-ownership-of-dcom-registry.html
  10.     #   http://www.remkoweijnen.nl/blog/2012/01/16/take-ownership-of-a-registry-key-in-powershell/
  11.     #   https://powertoe.wordpress.com/2010/08/28/controlling-registry-acl-permissions-with-powershell/
  12.  
  13.     param($rootKey, $key, [System.Security.Principal.SecurityIdentifier]$sid = 'S-1-5-32-545', $recurse = $true)
  14.  
  15.     switch -regex ($rootKey) {
  16.         'HKCU|HKEY_CURRENT_USER'    { $rootKey = 'CurrentUser' }
  17.         'HKLM|HKEY_LOCAL_MACHINE'   { $rootKey = 'LocalMachine' }
  18.         'HKCR|HKEY_CLASSES_ROOT'    { $rootKey = 'ClassesRoot' }
  19.         'HKCC|HKEY_CURRENT_CONFIG'  { $rootKey = 'CurrentConfig' }
  20.         'HKU|HKEY_USERS'            { $rootKey = 'Users' }
  21.     }
  22.  
  23.     ### Step 1 - escalate current process's privilege
  24.     # get SeTakeOwnership, SeBackup and SeRestore privileges before executes next lines, script needs Admin privilege
  25.     $import = '[DllImport("ntdll.dll")] public static extern int RtlAdjustPrivilege(ulong a, bool b, bool c, ref bool d);'
  26.     $ntdll = Add-Type -Member $import -Name NtDll -PassThru
  27.     $privileges = @{ SeTakeOwnership = 9; SeBackup =  17; SeRestore = 18 }
  28.     foreach ($i in $privileges.Values) {
  29.         $null = $ntdll::RtlAdjustPrivilege($i, 1, 0, [ref]0)
  30.     }
  31.  
  32.     function Take-KeyPermissions {
  33.         param($rootKey, $key, $sid, $recurse, $recurseLevel = 0)
  34.  
  35.         ### Step 2 - get ownerships of key - it works only for current key
  36.         $regKey = [Microsoft.Win32.Registry]::$rootKey.OpenSubKey($key, 'ReadWriteSubTree', 'TakeOwnership')
  37.         $acl = New-Object System.Security.AccessControl.RegistrySecurity
  38.         $acl.SetOwner($sid)
  39.         $regKey.SetAccessControl($acl)
  40.  
  41.         ### Step 3 - enable inheritance of permissions (not ownership) for current key from parent
  42.         $acl.SetAccessRuleProtection($false, $false)
  43.         $regKey.SetAccessControl($acl)
  44.  
  45.         ### Step 4 - only for top-level key, change permissions for current key and propagate it for subkeys
  46.         # to enable propagations for subkeys, it needs to execute Steps 2-3 for each subkey (Step 5)
  47.         if ($recurseLevel -eq 0) {
  48.             $regKey = $regKey.OpenSubKey('', 'ReadWriteSubTree', 'ChangePermissions')
  49.             $rule = New-Object System.Security.AccessControl.RegistryAccessRule($sid, 'FullControl', 'ContainerInherit', 'None', 'Allow')
  50.             $acl.ResetAccessRule($rule)
  51.             $regKey.SetAccessControl($acl)
  52.         }
  53.  
  54.         ### Step 5 - recursively repeat steps 2-5 for subkeys
  55.         if ($recurse) {
  56.             foreach($subKey in $regKey.OpenSubKey('').GetSubKeyNames()) {
  57.                 Take-KeyPermissions $rootKey ($key+'\'+$subKey) $sid $recurse ($recurseLevel+1)
  58.             }
  59.         }
  60.     }
  61.  
  62.     Take-KeyPermissions $rootKey $key $sid $recurse
  63. }
  64.  
  65. Take-Permissions "HKLM" "SYSTEM\CurrentControlSet\Enum\USB"
  66.  
  67. Take-Permissions "HKLM" "SYSTEM\CurrentControlSet\Enum\USB" "S-1-1-0"
  68.  
  69. Start-Sleep 1
  70. $Subkeys1 = Get-Childitem -Path "REGISTRY::HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\USB\*" | Select -expand Name
  71. foreach ($Subkey in $Subkeys1)
  72.         {
  73.             $Subkeys2 = ForEach-Object {Get-Childitem -Path "REGISTRY::$Subkey\*" | Select -expand Name}
  74.                 foreach ($Subkey2 in $Subkeys2)
  75.                 {
  76.                    
  77.                     Write-Host "Disabling $Subkey2\Device Parameters - DeviceSelectiveSuspended"
  78.                     Set-ItemProperty -Path "REGISTRY::$Subkey2\Device Parameters" -Name "DeviceSelectiveSuspended" -Type DWord -Value "0"
  79.                    
  80.                     Write-Host "Disabling  $Subkey2\Device Parameters - SelectiveSuspendOn"
  81.                     Set-ItemProperty -Path "REGISTRY::$Subkey2\Device Parameters" -Name "SelectiveSuspendOn" -Type DWord -Value "0"
  82.                    
  83.                     Write-Host "Disabling $Subkey2\Device Parameters - SelectiveSuspendEnabled"
  84.                     Set-ItemProperty -Path "REGISTRY::$Subkey2\Device Parameters" -Name "SelectiveSuspendEnabled" -Type Binary -Value "00"
  85.                    
  86.                 }
  87.         }      
  88. cmd /c pause       
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement