Solved

shared Mailboxes full report

Posted on 2010-09-02
4
1,252 Views
Last Modified: 2012-05-10
Hello,

I need to report detailed statistics from shared mailboxes on Exchange 07.
I tried to use get-mailboxpermission command but I can't filter all columns.

The final csv file should  include these properties: Mailbox_Name,WhenCreated,  Mailbox_smtp_address,RequireSenderAuthenticationEnabled (Yes/No),  HiddenFromAddressListsEnabled (Yes/No), Mailbox_database, ProhibitSendQuota
Prohibit_Send_Quota,Prohibit_Receive_Quota,IssueWarningQuota,  ,ManagedBy,Notes,Full_Access (users samaccountname),Send_As(users samaccountname),User_Account_Is_Blocked (Yes/No),Accept_Messages_from

I suppose that it wouldn't be an easy work to write such script because i don't know that all properties are available.
0
Comment
Question by:pi01162
  • 3
4 Comments
 
LVL 70

Expert Comment

by:Chris Dent
ID: 33586558

This gets us near to that. Anything missing?

You may have to clarify on what you mean by Accout_Is_Blocked and ManagedBy.

Chris
Get-Mailbox | ForEach-Object {
  $Stats = Get-MailboxStatistics $_.DistinguishedName

  $_ | Select-Object Name, WhenCreated, PrimarySmtpAddress, RequireSenderAuthenticationEnabled,
    HiddenFromAddressListsEnabled, Database, ProhibitSendQuota, ProhibitSendReceiveQuota, IssueWarningQuota,
    AcceptMessagesOnlyFrom, AcceptMessagesOnlyFromDLMembers, RejectMessagesFrom, RejectMessagesFromDLMembers,
    @{n='FullAccess';e={ 
      Get-MailboxPermission $_.DistinguishedName | 
        Where-Object { !$_.IsInherited -And $_.AccessRights -Match 'FullAccess' -And $_.User -NotMatch 'SELF' } |
        ForEach-Object { $_.User } }},
    @{n='SendAs';e={
      Get-ADPermission $_.DistinguishedName |
        Where-Object { !$_.Inherited -And $_.Rights -Match 'Send-As' } |
        ForEach-Object { $_.User } }}
}

Open in new window

0
 

Author Comment

by:pi01162
ID: 33596158
First thanks for reply!
ManagedBy (Shared mailbox manager) and Account_Is_Blocked (user's account is blocked in ActiveDirectory)
0
 

Author Comment

by:pi01162
ID: 33609690
Helo,

I tested this script and almost works except Send-As permission.
The script doesn't display those permissions. Full Acces is ok.

So please look again at Your's script and check "Send-As"

P.s Also I add manager field at the end
Get-Mailbox -organizationalunit 'domain.corp/Mailboxes' -id | ForEach-Object {



  $Stats = Get-MailboxStatistics $_.DistinguishedName



  $_ | Select-Object Name, WhenCreated, PrimarySmtpAddress, RequireSenderAuthenticationEnabled,

    HiddenFromAddressListsEnabled, Database, ProhibitSendQuota, ProhibitSendReceiveQuota, IssueWarningQuota,

    AcceptMessagesOnlyFrom, AcceptMessagesOnlyFromDLMembers, RejectMessagesFrom, RejectMessagesFromDLMembers,

    @{n='FullAccess';e={ 

      Get-MailboxPermission $_.DistinguishedName | 

        Where-Object { !$_.IsInherited -And $_.AccessRights -Match 'FullAccess' -And $_.User -NotMatch 'SELF' } |

        ForEach-Object { $_.User } }},

    @{n='SendAs';e={

      Get-AdPermission $_.DistinguishedName |

        Where-Object { !$_.Inherited -And $_.Rights -Match 'Send-As' } |

        ForEach-Object { $_.User } }},



    @{n='Manager';e={Get-User $_.DistinguishedName | select}}



}

Open in new window

0
 

Accepted Solution

by:
pi01162 earned 0 total points
ID: 33615278
Helo,
I correct the script (send-as permissions), the final version beneath
Get-Mailbox -OrganizationalUnit 'domain.corp/Mailboxes' | ForEach-Object {



  $Stats = Get-MailboxStatistics $_.DistinguishedName



  $_ | Select-Object Name, WhenCreated, PrimarySmtpAddress, RequireSenderAuthenticationEnabled,

    HiddenFromAddressListsEnabled, Database, ProhibitSendQuota, ProhibitSendReceiveQuota, IssueWarningQuota,

    @{Name="AcceptMessagesOnlyFrom";Expression={$_.AcceptMessagesOnlyFrom}}, @{Name="AcceptMessagesOnlyFromDLMembers";Expression={$_.AcceptMessagesOnlyFromDLMembers}}, @{Name="RejectMessagesFrom";Expression={$_.RejectMessagesFrom}},@{Name="RejectMessagesFromDLMembers";Expression={$_.RejectMessagesFromDLMembers}} ,

    @{n='FullAccess';e={ 

      Get-MailboxPermission $_.DistinguishedName | 

        Where-Object { !$_.IsInherited -And $_.AccessRights -Match 'FullAccess' -And $_.User -NotMatch 'SELF' } |

        ForEach-Object { $_.User } }},

    @{n='SendAs';e={

      Get-ADPermission $_.DistinguishedName |

        Where-Object { $_.ExtendedRights -like 'Send-As' -and  $_.User -NotMatch 'SELF'} |

        ForEach-Object { $_.User } }},

		

		@{n='Manager';e={Get-User $_.DistinguishedName | select}}

} |Export-Csv c:\MailboxfullReport.csv -NoTypeInformation

Open in new window

0

Featured Post

Best Practices: Disaster Recovery Testing

Besides backup, any IT division should have a disaster recovery plan. You will find a few tips below relating to the development of such a plan and to what issues one should pay special attention in the course of backup planning.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Are you one of those front-line IT Service Desk staff fielding calls, replying to emails, all-the-while working to resolve end-user technological nightmares? I am! That's why I have put together this brief overview of tools and techniques I use in o…
This article explains how to prepare an HTML email signature template file containing dynamic placeholders for users' Azure AD data. Furthermore, it explains how to use this file to remotely set up a department-wide email signature policy in Office …
Sending a Secure fax is easy with eFax Corporate (http://www.enterprise.efax.com). First, just open a new email message. In the To field, type your recipient's fax number @efaxsend.com. You can even send a secure international fax — just include t…
With the power of JIRA, there's an unlimited number of ways you can customize it, use it and benefit from it. With that in mind, there's bound to be things that I wasn't able to cover in this course. With this summary we'll look at some places to go…

895 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

15 Experts available now in Live!

Get 1:1 Help Now