We use cookies to improve your experience.
By your continued use of this site you accept such use.
For more details please see our privacy policy and cookies policy.

Script repository

Enable MFA with phone number for a user in Microsoft 365

October 11, 2023 Views: 2398

The script enables MFA in Microsoft 365 for the target user with phone number applied. It can be used in a business rule, custom command or scheduled task configured for the User object type.

To use the script, install Microsoft.Graph on the computer where Adaxes service runs.

Parameters:

  • $phoneType - specifies the phone type for multi-factor authentication.
  • $phoneNumberProperty - specifies the name of the property containing the required phone number. The name of the property should be as it is in the directory schema.
Edit Remove
PowerShell
$phoneType = "mobile" # TODO: modify me
$phoneNumberPropertyName = "telephoneNumber" # TODO: modify me

# Get phone number
try
{
    $phoneNumber = $Context.TargetObject.Get($phoneNumberPropertyName)
}
catch
{
    $Context.LogMessage("Phone number is not specified", "Warning")
    return
}
    
if ($NULL -eq $Context.TargetObject.AzureId)
{
   $Context.LogMessage("The user doesn't have an account in Microsoft 365", "Warning")
   return
}

try
{
   # Connect to Microsoft Graph
   $token = $Context.CloudServices.GetAzureAuthAccessToken("https://graph.microsoft.com")
   $token = $token | ConvertTo-SecureString -AsPlainText -Force

   Connect-MgGraph -AccessToken $token
       
   # Enable the authentication method
   try
   {
      New-MgUserAuthenticationPhoneMethod -UserId $Context.TargetObject.AzureId -PhoneType $phoneType -PhoneNumber $phoneNumber -ErrorAction Stop
   }
   catch
   {
      throw $_.Exception
   }
}
finally
{
   # Release resources
   Disconnect-MgGraph
}
Comments 2
avatar
Mike May 12, 2025
Could you please share a script to only enable MFA without selecting MFA method.
avatar
Support May 13, 2025
Hello Mike,

Unfortunately, we do not have such a script. Moreover, it looks like there is no such possibility since the deprecation of the MSOnline PowerShell module. However, you can try checking with Microsoft support.
Leave a comment
Loading...

Got questions?

Support Questions & Answers