我试图弄清楚如何做这种事情,但使用 PowerShell 调用(来自 C#)。我们正在迁移到 Exchange 2010,而我的旧代码不想工作,因此使用了 PowerShell。
IExchangeMailbox exMb = (IExchangeMailbox)userDe.NativeObject;
IADsSecurityDescriptor securityDescriptor = (IADsSecurityDescriptor)exMb.MailboxRights;
IADsAccessControlList acl = (IADsAccessControlList)securityDescriptor.DiscretionaryAcl;
AccessControlEntry ace = new AccessControlEntry();
...
...
我的邮箱可以使用:
using (PowerShell powershell = PowerShell.Create())
{
powershell.AddCommand("Get-Mailbox");
powershell.AddParameter("Identity", username);
runspace.Open();
powershell.Runspace = runspace;
return powershell.Invoke()[0];
}
但是,如果我随后将结果传递给类似的方法来获取 ACL,那么我就可以开始修改它,就像这样
using (PowerShell powershell = PowerShell.Create())
{
powershell.AddCommand("Get-Acl");
powershell.AddArgument(mailbox);
runspace.Open();
powershell.Runspace = runspace;
return powershell.Invoke()[0];
}
...我明白了
术语“Get-Acl”未被识别为 cmdlet 的名称
...从日志中出来。我还尝试了“Get-ACL”以防它区分大小写,但我认为第一个版本是正确的。
我也尝试过 Get-MailboxPermission 但是文档说它甚至没有返回类型,所以它不会给我一个对象来操作。
请帮忙