To perform a large number of tasks, especially custom automated tasks, it is necessary to connect to the Office 365 tenant with Powershell. If you are familiar with Powershell in Exchange then the commands are very similar. Clearly there are additional cmdlets that are relevant to Office 365 and in other articles we can explore those.

The main function however is to get the connection running in the first place. To do this you need to start up ‘Windows Powershell ISE’ from your desktop and Run As Administrator. The running as administrator is very important as it will not connect if you don’t.

As a pre-requisite to this you will need to install the Microsoft Office 365 Online Sign In Assistant. You can find the executable

Also the Azure AD modules can be downloaded here The short version of these instructions is to simply type the following command in the Powershell console

install-module azureadpreview

To import these modules into your Powershell sessions after you have installed them, type these commands in the Powershell console.

import-module msonline

import-module azureadpreview

If this is the very first time you have run this type of script on your machine, you will need to start by executing this command as a ‘one-off’.

Set-ExecutionPolicy RemoteSigned

After this point on your machine you will be able to run any kind of script via the Powershell ISE. Then you can use the following script to perform the connection.

$username = “”

$password = ConvertTo-SecureString “xxxxxx” -AsPlainText -Force

$UserCredential = new-object -typename System.Management.Automation.PSCredential -ArgumentList $username, $password

Set-ExecutionPolicy RemoteSigned

$Session = New-PSSession -ConfigurationName Microsoft.Exchange -ConnectionUri -Credential $UserCredential -Authentication Basic -AllowRedirection Import-PSSession $Session

import-module msonline

connect-MsolService -Credential $UserCredential

import-module azureadpreview

connect-AzureAD -Credential $UserCredential

Replace the items with Red X’s with the credentials for your tenant. The end result will look like this.

From here you can use normal Exchange style powershell to perform functions on Office 365.