data:image/s3,"s3://crabby-images/76c35/76c3504cef8b8b31c956a6acee58e0b47b4dee6d" alt="PowerShell, Azure : Access Azure AD via CLI with MFA"
A pretty simple one but something that seems to stump a lot of people. Much of the guidance around connecting to Azure AD suggests you do the following, :
Connect-AzureAD -Credential (Get-Credential)
Which is fine for accounts without MFA but lets break this down and we can see why it wont work for accounts with MFA.
- 'Connect-AzureAD' - A function that is part of the Azure AD module.
- '-credential' - An argument passed to the previous command.
- '(Get-Credential)' - The value we are passing is the result of the 'Get-Credential' function. This function only has the ability to collect username and password
So we can see that 'Get-Credential' is the problem, and if we run that command we can see it in action.
data:image/s3,"s3://crabby-images/3082e/3082e69b75cb9864af1542de9bfd182810e1bcb5" alt=""
So how do we get passed this if we are trying to log in via a MFA user? Well its much more simple that you would expect.
Connect-AzureAD
The same command without any arguments will prompt the M365 login page your are probably familiar with and will take you via your choses MFA method automatically.
data:image/s3,"s3://crabby-images/fc421/fc42120c0975d9e9ebd3b5ccd306f3b86db7dd0f" alt=""
Once you have negotiated authentication you will get the familiar summary of your current session.
data:image/s3,"s3://crabby-images/b14d1/b14d10f064f0f72378b74d032fb7300a482bb573" alt=""
This is all good and well if you are directly working on something but how would you do this in a scheduled script? Well that dear readers will the subject of another article.