Migrating to Exchange Online (EXO) using Exchange Hybrid? Make sure to migrate mailboxes with the same manager or delegate (associated delegates) in the same batch otherwise their access to each other's mailbox will be broken. This is because Send-As, Receive-As, or Send on behalf cross premises permissions are not supported with Exchange hybrid environments. You can read all about it here: https://technet.microsoft.com/en-us/library/jj906433(v=exchg.150).aspx
This script was developed to assist customers with their exchange hybrid migrations into Exchange Online. With this script you can export Exchange 2010/2013 on premises permissions, find their associated delegates (ie spider web batching), and produce a report of mailbox batches that can be used to migrate mailboxes without impacting users.
- Exchange 2010
- Exchange 2013
- Powershell v3+
- Exchange Management Tools
THIS CODE IS PROVIDED AS IS WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING ANY IMPLIED WARRANTIES OF FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR NON-INFRINGEMENT.
- Collect permissions
- Find batches based on the output permissions
- Create migration schedule (this is built in the format required by the Microsoft FastTrack Mail Migration team)
-
PARAMETER InputMailboxesCSV
Use this parameter to specify a list of users to collect permissions for, rather than all mailboxes. Make sure that the CSV file provided has a header titled "PrimarySMTPAddress" -
PARAMETER ExcludeServiceAcctsCSV
In cases where you have service accounts with permissions to a large number of mailboxes, e.g. Blackberry service accounts, you can use this to exclude those accounts from the batching processing. Provide the path to a csv file (no header needed) with each service account primarySMTPaddress on its own line. -
PARAMETER FullAccess
Collect Full Access permissions. Keep in mind that "Full Access" permissions are now supported in cross premises scenarios. Not including "Full Access" will speed up processing. -
PARAMETER SendOnBehalfTo
Collect SendOnBehalfTo permissions -
PARAMETER Calendar
Collect calendar permissions -
PARAMETER SendAs
Collect Send As permissions -
PARAMETER EnumerateGroups
This will enumerate groups that have permissions to mailboxes and include in the batching logic.
This will slow down processing.
-
PARAMETER ExcludeGroupsCSV
Use this to exclude groups that you don't want to enumerate. Provide the path to a csv file (no header needed) with each group name on its own line. -
PARAMETER ExchServerFQDN
Connect to a specific Exchange Server -
PARAMETER Resume
Use this to resume the script in case of a failure while running the script on a large number of users. This way you don't have to start all over. The way this works is that it will look for the progress xml file where it keeps track of mailboxes that are pending processing. Make sure not to use in conjunction with the InputMailboxesCSV switch. -
PARAMETER BatchUsers
Use this if you want to skip collecting permissions and only run Step 2 and Step 3. Make sure you have the permissions output file in the same directory (Find-MailboxDelegates-Permissions.csv). -
EXAMPLE
#Export only SendOnBehalfTo and Send As permissions and Enumerate Groups for all mailboxes.
.\Find-MailboxDelegates.ps1 -SendOnBehalfTo -SendAs -EnumerateGroups -
EXAMPLE
#Export only Full Access and Send As permissions and Enumerate Groups for the provided user list. Make sure to use "PrimarySMTPAddress" as header.
.\Find-MailboxDelegates.ps1 -InputMailboxesCSV "C:\Users\administrator\Desktop\userlist.csv" -FullAccess -SendAs -EnumerateGroups -
EXAMPLE
#Resume the script after a script interruption and failure to pick up on where it left off. Make sure to include the same switches as before EXCEPT the InputMailboxesCSV otherwise it'll yell at you
.\Find-MailboxDelegates.ps1 -FullAccess -SendAs -EnumerateGroups -Resume -
EXAMPLE
#Export all permissions and enumerate groups for all mailboxes
.\Find-MailboxDelegates.ps1 -FullAccess -SendOnBehalfTo -SendAs -Calendar -EnumerateGroups -
EXAMPLE
#Export all permissions but don't enumerate groups for all mailboxes
.\Find-MailboxDelegates.ps1 -FullAccess -SendOnBehalfTo -SendAs -Calendar -
EXAMPLE #Export all permissions and exclude service accounts for all mailboxes
.\Find-MailboxDelegates.ps1 -FullAccess -SendOnBehalfTo -SendAs -Calendar -ExcludeServiceAcctsCSV "c:\serviceaccts.csv" -
EXAMPLE
#Export all permissions and exclude service accounts for all mailboxes
.\Find-MailboxDelegates.ps1 -FullAccess -SendOnBehalfTo -SendAs -Calendar -ExcludeServiceAcctsCSV "c:\serviceaccts.csv" -ExcludeGroupsCSV "c:\groups.csv" -
EXAMPLE
#Skip collect permissions (assumes you already have a permissions output file) and only run Step 2 and 3 to batch users
.\Find-MailboxDelegates.ps1 -BatchUsers
If you want to contribute and/or provide feedback, please reach out to:
Alejandro Lopez - [email protected]
Sam Portelli - [email protected]