Eu tenho uma função Powershell que faz parte disso, mas não usa a conta de domínio para apropriar-se e adicionar permissões ... ele usa um administrador local. Existe uma maneira melhor de fazer isso em Powershell?
<#
.SYNOPSIS
Take ownership of a folder giving the ownership to ourdomain\myuser
.DESCRIPTION
Takes ownership of a file the way my boss said to do when deleting a user's home directory.
Using the GUI:
1. Right click the folder and select properties.
2. Click the "Security" tab.
3. Click the "Advanced" button.
4. Next to the "Owner:" label, click "Change"
5. Enter ourdomain\myuser
6. Click OK, OK, OK
7. Right click the folder and select properties.
8. Click the "Security" tab.
9. Click the "Advanced" button.
10. Click "Add"
11. Next to "Principal:" click "Select a principal"
12. Enter ourdomain\myuser
13. Click OK
14. Check "Full control"
15. Click OK, OK, OK
16. You should now be able to manipulate or delete the folder.
.NOTES
File Name : Microsoft.PowerShell_profile.ps1
.EXAMPLE
Take-Ownership R:\Redirected\Users\<username>
#>
function Take-Ownership {
param(
[String]$Folder
)
# Take ownership of the folder...
# (though I'd prefer if I could specify a user or group instead)
takeown.exe /A /F $Folder
# Obtain the current ACL for this folder.
$CurrentACL = Get-Acl $Folder
# Add FullControl permissions to the ACL for the user.
Write-Host ...Adding ourdomain\myuser to $Folder -Fore Yellow
$SystemACLPermission = "ourdomain\myuser","FullControl","ContainerInherit,ObjectInherit","None","Allow"
$SystemAccessRule = new-object System.Security.AccessControl.FileSystemAccessRule $SystemACLPermission
$CurrentACL.AddAccessRule($SystemAccessRule)
#Write-Host ...Adding Infrastructure Services to $Folder -Fore Yellow
#$AdminACLPermission = "ourdomain\myuser","FullControl","ContainerInherit,ObjectInherit"."None","Allow"
#$SystemAccessRule = new-object System.Security.AccessControl.FilesystemAccessRule $AdminACLPermission
#$CurrentACL.AddAccessRule($SystemAccessRule)
# Set the ACL again.
Set-Acl -Path $Folder -AclObject $CurrentACL
}
windows
powershell
ntfs
file-permissions
acl
leeand00
fonte
fonte
takeown /s system /u domain\username /p password /f $folder /a
mais informações emtakeown /?
Respostas:
Se você estiver definindo o proprietário de um objeto para o grupo Administradores, será necessário ser um administrador local. Caso contrário, as pessoas poderiam contornar as cotas de disco, já que a contabilização de cotas é baseada na propriedade de arquivos e as cotas não afetam os administradores.
Se você estiver executando o script como administrador, poderá definir o proprietário de um objeto para qualquer entidade de segurança, depois de um pouco de brincadeira. Você precisará este script de ajuste de privilégio de Lee Holmes, que eu editei levemente para remover espaço em branco extra e permitir que ele seja executado várias vezes em uma sessão:
Salvei como
privs.ps1
. Você pode então ligar.\privs.ps1 SeRestorePrivilege
para ligarSeRestorePrivilege
para o seu processo, que permite definir a propriedade do arquivo para quem você quiser.Então, em vez do
takeown
chamada, você pode usar esse objeto ACL que você já tem:O novo proprietário será definido ao mesmo tempo em que a nova ACL for aplicada.
Finalmente, você pode desativar o privilégio extra:
fonte