Я бы сделал что-то вроде этого. Он выведет все общие почтовые ящики и пользователей, которые имеют к ним доступ. Для каждого пользователя отображаются права доступа к почтовому ящику. В зависимости от количества пользователей и общих почтовых ящиков обработка может занять некоторое время.
(Из-за [ordered]
вам потребуется Powershell версии 3 или выше. Чтобы использовать его в Powershell 2, удалите [ordered]
. Тогда порядок, в котором будут отображаться свойства, не гарантируется.)
function Get-AllMailboxPermissions {
$allMailboxes = Get-Mailbox -ResultSize Unlimited | Sort-Object Identity
if ($allMailboxes.Count -eq 0) {
Write-Warning "No mailboxes found."
return
}
foreach ($box in $allMailboxes) {
$perms = $box | Get-MailboxPermission |
Where-Object { $_.IsInherited -eq $false -and $_.User.ToString() -ne "NT AUTHORITY\SELF" -and $_.User.ToString() -notmatch '^S-1-' } |
Sort-Object User
foreach ($prm in $perms) {
$user = Get-Recipient -Identity $($prm.User.ToString()) -ErrorAction SilentlyContinue
# skip inactive (deleted) users
if ($user -and $user.DisplayName) {
$props = [ordered]@{
"Mailbox" = "$($box.Identity)"
"User" = $user.DisplayName
"AccessRights" = "$($prm.AccessRights -join ', ')"
}
New-Object PsObject -Property $props
}
}
}
}
Возможно, вы захотите сохранить эту информацию в файле csv. В этом случае вызовите функцию следующим образом:
Get-AllMailboxPermissions | Export-Csv -Path '<PATH-TO-OUTPUT.CSV>' -NoTypeInformation -Encoding UTF8 -Force
Совет. Если вы хотите открыть CSV-файл в Excel, дважды щелкнув его на том же компьютере, в командлете Export-Csv
есть очень полезный переключатель -UseCulture
. При этом разделитель в CSV-файле будет таким же, как и в Excel.
person
Theo
schedule
14.07.2018