I just started to play with a Microsoft Office 365 environment (Azure Active Directory, Lync Online and Exchange Online) and I thought I would make it through PowerShell obviously :-)
But when you start your PowerShell console... you need to load modules, connect to each services, enter your credentials...yada yada yada...
With Office 365 you can administer the following services using PowerShell:
- Azure Active Directory
- Exchange Online PowerShell
- SharePoint Online PowerShell
- Lync Online PowerShell
Note: However I was not able to test the SharePoint part, so this is not included in the function below yet.
Here is a very handy function that you can include to your PowerShell Profil to connect to all the service at once.
Requirements
- Azure Active Directory Download
- Exchange Online PowerShell (no download needed, the function will create an implicit remoting module)
- SharePoint Online PowerShell (no download needed, the function will create an implicit remoting module)
- Lync Online PowerShell Download
PowerShell Function Connect-Office365
function Connect-Office365 { <# .SYNOPSIS This function will prompt for credentials, load module MSOLservice, load implicit modules for Office 365 Services (AD, Lync, Exchange) using PSSession. .DESCRIPTION This function will prompt for credentials, load module MSOLservice, load implicit modules for Office 365 Services (AD, Lync, Exchange) using PSSession. .EXAMPLE Connect-Office365 This will prompt for your credentials and connect to the Office365 services .EXAMPLE Connect-Office365 -verbose This will prompt for your credentials and connect to the Office365 services. Additionally you will see verbose messages on the screen to follow what is happening in the background .NOTES Francois-Xavier Cat lazywinadmin.com @lazywinadm #> [CmdletBinding()] PARAM () BEGIN { TRY { #Modules IF (-not (Get-Module -Name MSOnline -ListAvailable)) { Write-Verbose -Message "BEGIN - Import module Azure Active Directory" Import-Module -Name MSOnline -ErrorAction Stop -ErrorVariable ErrorBeginIpmoMSOnline } IF (-not (Get-Module -Name LyncOnlineConnector -ListAvailable)) { Write-Verbose -Message "BEGIN - Import module Lync Online" Import-Module -Name LyncOnlineConnector -ErrorAction Stop -ErrorVariable ErrorBeginIpmoLyncOnline } } CATCH { Write-Warning -Message "BEGIN - Something went wrong!" IF ($ErrorBeginIpmoMSOnline) { Write-Warning -Message "BEGIN - Error while importing MSOnline module" } IF ($ErrorBeginIpmoLyncOnline) { Write-Warning -Message "BEGIN - Error while importing LyncOnlineConnector module" } Write-Warning -Message $error[0].exception.message } } PROCESS { TRY { # CREDENTIAL Write-Verbose -Message "PROCESS - Ask for Office365 Credential" $O365cred = Get-Credential -ErrorAction Stop -ErrorVariable ErrorCredential # AZURE ACTIVE DIRECTORY (MSOnline) Write-Verbose -Message "PROCESS - Connect to Azure Active Directory" Connect-MsolService -Credential $O365cred -ErrorAction Stop -ErrorVariable ErrorConnectMSOL # EXCHANGE ONLINE (Implicit Remoting module) Write-Verbose -Message "PROCESS - Create session to Exchange online" $ExchangeURL = "https://ps.outlook.com/powershell/" $O365PS = New-PSSession -ConfigurationName Microsoft.Exchange -ConnectionUri $ExchangeURL -Credential $O365cred -Authentication Basic -AllowRedirection -ErrorAction Stop -ErrorVariable ErrorConnectExchange Write-Verbose -Message "PROCESS - Open session to Exchange online (Prefix: Cloud)" Import-PSSession -Session $O365PS –Prefix ExchCloud # LYNC ONLINE (LyncOnlineConnector) Write-Verbose -Message "PROCESS - Create session to Lync online" $lyncsession = New-CsOnlineSession –Credential $O365cred -ErrorAction Stop -ErrorVariable ErrorConnectExchange Import-PSSession -Session $lyncsession -Prefix LyncCloud # SHAREPOINT ONLINE (Implicit Remoting module) #Connect-SPOService -Url https://contoso-admin.sharepoint.com –credential $O365cred } CATCH { Write-Warning -Message "PROCESS - Something went wrong!" IF ($ErrorCredential) { Write-Warning -Message "PROCESS - Error while gathering credential" } IF ($ErrorConnectMSOL) { Write-Warning -Message "PROCESS - Error while connecting to Azure AD" } IF ($ErrorConnectExchange) { Write-Warning -Message "PROCESS - Error while connecting to Exchange Online" } IF ($ErrorConnectLync) { Write-Warning -Message "PROCESS - Error while connecting to Lync Online" } Write-Warning -Message $error[0].exception.message } } }
Running the function
Here the result in action
Adding the function to your PowerShell profile
The next time you reload your PowerShell, the function Connect-Office365 will be available to your PowerShell.
Finally we can see two implicit modules created for Lync and Exchange with a sample of cmdlets available. Those cmdlets contains the prefix we defined in the function ExchCloud and LyncCloud.
![]() |
Implicit remoting modules loaded start by a "tmp". You can see a sample of the Cmdlets available with the prefix we included. |
Download
Space for improvements
- Check if PSsession already opened ? Same credential used?
- Parameters
- [Switch]$AzureAD,
- [Switch]$LyncOnline,
- [Switch]$ExchangeOnline
Thanks for reading! If you have any questions, leave a comment or send me an email at fxcat@lazywinadmin.com. I invite you to follow me on Twitter @lazywinadm / Google+ / LinkedIn. You can also follow the LazyWinAdmin Blog on Facebook Page and Google+ Page.