Considerations
MFA Enforcement has evolved over time. Stop using per-user MFA.
- Enabled => Required users to perform MFA immediately across all logins
- Enforced => Allowed users to defer registering for MFA for 14 days
- Disabled => MFA not enforced
Conditional Access can quickly become swiss cheese. Ensure you have a blanket MFA policy for All Users.
- Temporarily adding users to overcome some operational constraint where MFA needs to be bypassed
- Users being excluded as they are going on international travel
- Inadvertent exclusions through group membership
- Includes All Users, only excludes break glass accounts
- Includes All Applications
- Does not whitelist any Networks to exclude from enforcement
- Does not have any other filtering going on
- Requires MFA in the Grant controls
MFA methods and the evolving attack surface
- Disabled SMS, Voice Call, and Email OTP
- Disable OTP on Authenticator and make sure number matching has been enabled
- Try to enforce phishing-resistant forms of MFA for Admin accounts (ex. FIDO2 keys/Passkeys for Global Admins)
data:image/s3,"s3://crabby-images/35f69/35f698ad06eb6f2a474e3c226d3d3f875ad16378" alt=""
There is no central MFA report
- The user has signed-in at least once
- They have some type of enforcement being applied that would have them register for MFA
- is this a licensed user
- is this a shared mailbox
- is this a service account
- is this a break glass account
- is the account enabled
Entra ID logs can help but are a lot of noise
data:image/s3,"s3://crabby-images/8f21f/8f21f41a7073a067937a3cfe5a295b873009101c" alt=""
data:image/s3,"s3://crabby-images/c7bd2/c7bd26c3920e45b109eccb02166bddced0da54c1" alt=""
data:image/s3,"s3://crabby-images/b8e7f/b8e7f13e08a51863946865c74e9f1e84580b1f48" alt=""
Tools that can help with reporting
- Stop using per-user MFA. Enforce a blanket conditional access policy for MFA.
- Disable legacy forms of MFA.
- User the User Registration Details and Activity report to review who is capable for MFA
- Periodically review your conditional access policy exclusions and the coverage report
The following are other tools I recommend that can help with the reporting and monitoring of MFA across your customers:
data:image/s3,"s3://crabby-images/1b4d7/1b4d7a970104eefa638fec2fe753c90b3e5a80f4" alt=""
data:image/s3,"s3://crabby-images/9ea1f/9ea1f44e596bbac1fc513d9446bc9cb386b00149" alt=""
- Licensed users that:
- Are enabled
- Have a mailbox
- Are not a shared mailbox
- Are not covered by Conditional Access
- Are not covered by Security defaults
- Have not been registered for MFA
data:image/s3,"s3://crabby-images/ef238/ef2382d3efd32e8766e031b504b2b7d7bc42cc50" alt=""
data:image/s3,"s3://crabby-images/bd28b/bd28bf98d59e866ce345bcabec448c777cb8c787" alt=""
Run a free assessment on a tenant to see what this report looks like for you.
data:image/s3,"s3://crabby-images/64106/641065053644e29a29e2c6f64d014f3a49ed32c1" alt=""
data:image/s3,"s3://crabby-images/e4c6f/e4c6fb1aec1b627b532d34444d6d504acf9534c9" alt=""
Bonus: APIs that help with reporting:
Getting Users Default MFA Method: https://learn.microsoft.com/en-us/graph/api/authentication-get?view=graph-rest-beta&tabs=http
Getting Users Per-User MFA State (new): https://learn.microsoft.com/en-us/graph/api/authentication-get?view=graph-rest-beta&tabs=http#example-2-get-a-users-mfa-state
Getting Users Additional MFA detail: https://learn.microsoft.com/en-us/graph/api/authentication-list-methods?view=graph-rest-beta&tabs=http
Getting User MFA Registration Information: https://learn.microsoft.com/en-us/graph/api/reportroot-list-credentialuserregistrationdetails?view=graph-rest-beta&tabs=http