diff options
author | sagishahar <sagishahar@gmail.com> | 2016-01-17 23:04:27 +0800 |
---|---|---|
committer | sagishahar <sagishahar@gmail.com> | 2016-01-17 23:04:27 +0800 |
commit | 3f1dd3450061eece07a18821fbd7ff4f5b3fb907 (patch) | |
tree | 10d361ab02a4d116cf68a78a745a9396de9b11cf /Privesc | |
parent | 872d4b0eb74072465980567d5cf2cb42fa0283d5 (diff) | |
download | PowerSploit-3f1dd3450061eece07a18821fbd7ff4f5b3fb907.tar.gz PowerSploit-3f1dd3450061eece07a18821fbd7ff4f5b3fb907.zip |
Fix 'Install-ServiceBinary' for non-'Modifiable' files
The 'Install-ServiceBinary' function fails on an edge case where the
service's file permission does not include the 'Modify' permission but
does include the 'Write' permission
(https://technet.microsoft.com/en-au/library/dd349321(v=ws.10).aspx). In
this scenario, renaming the original service file for backup purposes
will result in 'Access Denied' message. Fixing this requires that the
file be copied to service.exe.bak instead of renamed to service.exe.bak.
Diffstat (limited to 'Privesc')
-rw-r--r-- | Privesc/PowerUp.ps1 | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/Privesc/PowerUp.ps1 b/Privesc/PowerUp.ps1 index 0d71b14..0661122 100644 --- a/Privesc/PowerUp.ps1 +++ b/Privesc/PowerUp.ps1 @@ -794,7 +794,7 @@ function Write-ServiceBinary { The service name the EXE will be running under. Required. - .PARAMETER Path + .PARAMETER ServicePath Path to write the binary out to, defaults to the local directory. @@ -920,7 +920,7 @@ function Install-ServiceBinary { <# .SYNOPSIS - Users Write-ServiceBinary to write a C# service that creates a local UserName + Uses Write-ServiceBinary to write a C# service that creates a local UserName and adds it to specified LocalGroup or executes a custom command. Domain users are only added to the specified LocalGroup. @@ -1006,7 +1006,7 @@ function Install-ServiceBinary { Write-Verbose "Backing up '$ServicePath' to '$BackupPath'" try { - Move-Item -Path $ServicePath -Destination $BackupPath -Force + Copy-Item -Path $ServicePath -Destination $BackupPath -Force } catch { Write-Warning "[*] Original path '$ServicePath' for '$ServiceName' does not exist!" |