MFA Shall Be Required for All Users
Last updated
Last updated
MFA, or multi-factor authentication, is a security measure that requires users to provide multiple forms of identification to gain access to a system or network. By enforcing MFA within an organization, companies can better protect themselves against cyber threats, such as hacking and identity theft.
At a minimum, users with privileged roles such as Global Administrators should have MFA enforced. Where possible, phishing-resistant MFA should be required for all users. Phishing-resistant multifactor authentication protects against sophisticated phishing attacks. Phishing-resistant MFA may not always be immediately available, especially on mobile devices. Where phishing-resistant MFA is not yet available, organization should adopt an MFA method from the list below
Microsoft also encourages a break-glass account to ensure that you are not accidently locked out of your organization. These accounts are referred to as emergency access accounts and should be excluded from MFA enforcement.
MFA can be enforced with per user settings, Conditional Access Policies, or Security Defaults. Per user settings will be deprecated in January of 2024. Since February of 2022, Security Defaults are enabled on all new tenants which requires MFA for all users. Security defaults are NOT a hard requirement for non-partner tenants but are recommended. If you have a tenant licensed with conditional access, it is recommended that you enforce conditional access policies instead of security defaults.
MFA is enforced for all users
Phishing Resistant MFA is enforced for all users
If phishing Resistant MFA cannot be used, and MFA method from the list below shall be used temporarily
Microsoft Authenticator (Push Notifications)
Microsoft Authenticator (Passwordless-SignIn)
While using Microsoft Authenticator:
Number Matching shall be enabled
Geolocation shall be enabled
Software Tokens One-Time Password (OTP) โ This option is commonly implemented using mobile phone authenticator apps.
Hardware tokens OTP
SMS and Voice shall not be used as the MFA method
One emergency, break-glass account shall be created and excluded from MFA enforcement
Accounts excluded from MFA shall be documented and include a justification reason
Enforcing MFA through conditional access requires an Azure AD P1 license which can be purchased standalone or through the following common plans:
Microsoft 365 Business Premium
EMS + E3 or EMS + E5
Microsoft 365 E3
Microsoft 365 E5
OATH Hardware Tokens require Azure AD P1 or P2 Licensing
Enforcing MFA per user or through Security Defaults is available through all Microsoft Licensing Plans
Requiring All users to have MFA through conditional Access: Require MFA for all users with Conditional Access - Azure Active Directory - Microsoft Entra | Microsoft Learn
Security Defaults in Azure AD: Providing a default level of security in Azure Active Directory - Microsoft Entra | Microsoft Learn
Legacy Per user MFA: Enable per-user Multi-Factor Authentication - Azure Active Directory - Microsoft Entra | Microsoft Learn
Migrating from Legacy Per User Settings: How to migrate to the Authentication methods policy - Azure Active Directory (preview) - Microsoft Entra | Microsoft Learn
Phishing Resistant MFA:
Certificate Based Authentication: How to configure Azure AD certificate-based authentication - Azure Active Directory - Microsoft Entra | Microsoft Learn
Password Less Sign In with Microsoft Authenticator: Passwordless sign-in with Microsoft Authenticator - Azure Active Directory - Microsoft Entra | Microsoft Learn
Using Number matching: Use number matching in multifactor authentication (MFA) notifications - Azure Active Directory - Microsoft Entra | Microsoft Learn
Using Geolocation: Use additional context in Microsoft Authenticator notifications - Azure Active Directory - Microsoft Entra | Microsoft Learn
What Authentication methods are available in AAD: Authentication methods and features - Azure Active Directory - Microsoft Entra | Microsoft Learn
1. In the Azure Portal navigate to Azure Active Directory.
2. Select Security.
3. Select Manage -> MFA.
4. Under Configure, select Additional cloud-based MFA settings.
5. Under verification options, select Notification through mobile app.
6. If desired, to enforce Microsoft Authenticator app usage and disable third party authenticator apps usage, make sure that Verification code from mobile app or hardware token is not selected.
7. Click Save.
8. Go back to the Azure Active Directory home tab and select Security.
9. Select Authentication Methods.
10. In the Policies window, select Microsoft Authenticator.
11. For Enable, select Yes.
12. For Target, select All users.
13. In the row for the All users, click the โฆ -> Configure.
14. If configuring Phone Sign-in (aka Passwordless Sign-in), for Authentication mode, select Passwordless. If configuring Push Notifications, for Authentication mode, select Push. If configuring the usage of both, for Authentication mode, select Any.
a. For Require number matching, select Enabled.
b. For Show additional context in notifications, select Enabled.
15. Select Done.
16. Click Save
Level: High
End-User impact is high due to the necessary configuration steps along and prompts to fulfill MFA request. The user experience will vary depending on which MFA methods you have set up. In my CIS section, I have end-user notifications available as part of the Security Baselines document.
Tips:
Create a group in Azure Active Directory used to place all accounts excluded from MFA. This would be your emergency break-glass account and service accounts such as the Azure AD Connect sync service account (if you are running a hybrid environment).
If you are not able to enforce phishing-resistant MFA across all users, at minimum try to enable it for accounts with privileged roles (Global Admins, User Admins, etc.)
Convert from per-user MFA to Conditional Access MFA: Move from per-user MFA to Conditional Access MFA - ALI TAJRAN
MFA Status Reporting (Multi-tenant): Security/MFA Status_Custom Control_All Customers.ps1 at master ยท msp4msps/Security (github.com)