mirror of https://github.com/raandree/NTFSSecurity
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
108 lines
3.2 KiB
108 lines
3.2 KiB
using Alphaleonis.Win32.Filesystem;
|
|
using Security2;
|
|
using System;
|
|
using System.Management.Automation;
|
|
|
|
namespace NTFSSecurity
|
|
{
|
|
[Cmdlet(VerbsCommon.Set, "NTFSOwner", DefaultParameterSetName = "Path")]
|
|
[OutputType(typeof(FileSystemOwner))]
|
|
public class SetOwner : BaseCmdletWithPrivControl
|
|
{
|
|
private SwitchParameter passThru;
|
|
private IdentityReference2 account;
|
|
|
|
[Parameter(Position = 1, ValueFromPipeline = true, ValueFromPipelineByPropertyName = true, ParameterSetName = "Path")]
|
|
[ValidateNotNullOrEmpty]
|
|
[Alias("FullName")]
|
|
public string[] Path
|
|
{
|
|
get { return paths.ToArray(); }
|
|
set
|
|
{
|
|
paths.Clear();
|
|
paths.AddRange(value);
|
|
}
|
|
}
|
|
|
|
[Parameter(Mandatory = true, Position = 1, ValueFromPipeline = true, ValueFromPipelineByPropertyName = true, ParameterSetName = "SecurityDescriptor")]
|
|
[ValidateNotNullOrEmpty]
|
|
public FileSystemSecurity2[] SecurityDescriptor
|
|
{
|
|
get { return securityDescriptors.ToArray(); }
|
|
set
|
|
{
|
|
securityDescriptors.Clear();
|
|
securityDescriptors.AddRange(value);
|
|
}
|
|
}
|
|
|
|
[Parameter(Mandatory = true, Position = 2, ValueFromPipelineByPropertyName = true)]
|
|
public IdentityReference2 Account
|
|
{
|
|
get { return account; }
|
|
set { account = value; }
|
|
}
|
|
|
|
[Parameter]
|
|
public SwitchParameter PassThru
|
|
{
|
|
get { return passThru; }
|
|
set { passThru = value; }
|
|
}
|
|
|
|
protected override void BeginProcessing()
|
|
{
|
|
base.BeginProcessing();
|
|
}
|
|
|
|
protected override void ProcessRecord()
|
|
{
|
|
if (ParameterSetName == "Path")
|
|
{
|
|
foreach (var path in paths)
|
|
{
|
|
FileSystemInfo item = null;
|
|
|
|
try
|
|
{
|
|
item = GetFileSystemInfo2(path);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
WriteError(new ErrorRecord(ex, "ReadFileError", ErrorCategory.OpenError, path));
|
|
continue;
|
|
}
|
|
|
|
try
|
|
{
|
|
FileSystemOwner.SetOwner(item, account);
|
|
WriteDebug("Owner set on item {0}", item.FullName);
|
|
|
|
if (passThru)
|
|
{
|
|
WriteObject(FileSystemOwner.GetOwner(item));
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
WriteError(new ErrorRecord(ex, "SetOwnerError", ErrorCategory.WriteError, path));
|
|
continue;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
foreach (var sd in securityDescriptors)
|
|
{
|
|
FileSystemOwner.SetOwner(sd, account);
|
|
|
|
if (passThru)
|
|
{
|
|
WriteObject(FileSystemOwner.GetOwner(sd));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|