Plan a Conditional Access deployment
Planning your Conditional Access deployment is critical to achieving your organization's access strategy for apps and resources.
In a mobile-first, cloud-first world, your users access your organization's resources from anywhere using a variety of devices and apps. As a result, focusing on who can access a resource is no longer enough. You also need to consider where the user is, the device being used, the resource being accessed, and more.
Azure Active Directory (Azure AD) Conditional Access analyses signals such as user, device, and location to automate decisions and enforce organizational access policies for resource. You can use Conditional Access policies to apply access controls like Multi-Factor Authentication (MFA). Conditional Access policies allow you to prompt users for MFA when needed for security, and stay out of users’ way when not needed.
Microsoft provides standard conditional policies called security defaults that ensure a basic level of security. However, your organization may need more flexibility than security defaults offer. You can use Conditional Access to customize security defaults with more granularity and to configure new policies that meet your requirements.
Before you begin, make sure you understand how Conditional Access works and when you should use it.
The benefits of deploying Conditional Access are:
Increase productivity. Only interrupt users with a sign-in condition like MFA when one or more signals warrants it. Conditional Access policies allow you to control when users are prompted for MFA, when access is blocked, and when they must use a trusted device.
Manage risk. Automating risk assessment with policy conditions means risky sign-ins are at once identified and remediated or blocked. Coupling Conditional Access with Identity Protection, which detects anomalies and suspicious events, allows you to target when access to resources is blocked or gated.
Manage cost. Moving access policies to Azure AD reduces the reliance on custom or on-premises solutions for Conditional Access, and their infrastructure costs.
If additional features are required, you might also need related licenses. For more information, see Azure Active Directory pricing.
A working Azure AD tenant with Azure AD Premium or trial license enabled. If needed, create one for free.
An account with Conditional Access administrator privileges.
A non-administrator user with a password you know, such as testuser. If you need to create a user, see Quickstart: Add new users to Azure Active Directory.
A group that the non-administrator user is a member of. If you need to create a group, see Create a group and add members in Azure Active Directory.
The following resources may be useful as you learn about Conditional Access:
- What is Conditional Access?
- How to deploy Conditional Access?
- How to roll out Conditional Access policies to end users?
- How to include or exclude users from Conditional Access policies
- Conditional Access with device controls
- Conditional Access with Azure AD MFA
- Conditional Access in Enterprise Mobility + Security
Online courses on PluralSight
- Design Identity Management in Microsoft Azure
- Design Authentication for Microsoft Azure
- Design Authorization for Microsoft Azure
Plan the deployment project
Consider your organizational needs while you determine the strategy for this deployment in your environment.
Engage the right stakeholders
When technology projects fail, they typically do so due to mismatched expectations on impact, outcomes, and responsibilities. To avoid these pitfalls, ensure that you're engaging the right stakeholders and that project roles are clear.
Communication is critical to the success of any new service. Proactively communicate with your users how their experience will change, when it will change, and how to gain support if they experience issues.
Plan a pilot
When new policies are ready for your environment, deploy them in phases in the production environment. First apply a policy to a small set of users in a test environment and verify if the policy behaves as expected. See Best practices for a pilot.
For rolling out new policies not specific to administrators, exclude all administrators. This ensures that administrators can still access the policy and make changes or revoke it if there's a significant impact. Always validate the policy with smaller user groups before you apply to all users.
Understand Conditional Access policy components
Conditional Access policies are if-then statements: If an assignment is met, then apply these access controls.
When configuring Conditional Access policies, conditions are called assignments. Conditional Access policies allow you to enforce access controls on your organization’s apps based on certain assignments.
For more information, see Building a Conditional Access policy.
Assignments define the
Users and groups to be affected by the policy
Cloud apps or actions to which the policy will apply
Conditions under which the policy will apply.
Access controls settings determine how to enforce a policy:
Grant or Block access to cloud apps.
Session controls enable limited experiences within specific cloud apps.
Ask the right questions to build your policies
Policies answer questions about who should access your resources, what resources they should access, and under what conditions. Policies can be designed to grant access, or to block access. Be sure to ask the right questions about what your policy is trying to achieve.
Document the answers to questions for each policy before building it out.
Common questions about Assignments
Which users and groups will be included in or excluded from the policy?
Does this policy include all users, specific group of users, directory roles, or external users?
What application(s) will the policy apply to?
What user actions will be subject to this policy?
Which device platforms will be included in or excluded from the policy?
What are the organization’s trusted locations?
What locations will be included in or excluded from the policy?
What client app types (browser, mobile, desktop clients, apps with legacy authentication methods) will be included in or excluded from the policy?
Do you have policies that would drive excluding Azure AD Joined devices or Hybrid Azure AD joined devices from policies?
If using Identity Protection, do you want to incorporate sign-in risk protection?
Common questions about access controls
Do you want to grant access to resources by requiring one or more of the following?
Require device to be marked as compliant
Require hybrid Azure AD joined device
Require approved client app
Require app protection policy
Do you want to enforce any of the following access controls on cloud apps?
Use app enforced permissions
Use Conditional Access App Control
Enforce sign-in frequency
Use persistent browser sessions
Access token issuance
It’s important to understand how access tokens are issued.
If no assignment is required, and no Conditional Access policy is in effect, that the default behavior is to issue an access token.
For example, consider a policy where:
IF user is in Group 1, THEN force MFA to access App 1.
If a user not in Group 1 attempts to access the app no “if’ condition is met, and a token is issued. To exclude users outside of Group 1 requires a separate policy to block all other users.
Follow best practices
The Conditional Access framework provides you with a great configuration flexibility. However, great flexibility also means you should carefully review each configuration policy before releasing it to avoid undesirable results.
Apply Conditional Access policies to every app
Access tokens are by default issued if a Conditional Access policy condition does not trigger an access control. Ensure that every app has at least one conditional access policy applied
Be very careful in using block and all apps in a single policy. This could lock admins out of the Azure Administration Portal, and exclusions cannot be configured for important end-points such as Microsoft Graph.
Minimize the number of Conditional Access policies
Creating a policy for each app isn't efficient and leads to complex administration. There can be a maximum of 195 Conditional Access in each Azure AD tenant. We recommend that you analyze your apps and group them into policies that have the same access requirements. For example, if all Microsoft 365 apps or all HR apps have the same requirements for the same users, create a single policy and include all of these apps instead of adding a policy for each app.
Set up emergency access accounts
If you misconfigure a policy, it can lock the organizations out of the Azure portal. Mitigate the impact of accidental administrator lock out by creating two or more emergency access accounts in your organization.
- Create a user account dedicated to policy administration and excluded from all your policies.
Set up report-only mode
It can be difficult to predict the number and names of users affected by common deployment initiatives such as:
- blocking legacy authentication
- requiring MFA
- implementing sign-in risk policies
Report-only mode allows administrators to evaluate the impact of Conditional Access policies before enabling them in their environment.
Plan for disruption
If you rely on a single access control, such as MFA or a network location, to secure your IT systems, you are susceptible to access failures if that single access control becomes unavailable or misconfigured. To reduce the risk of lockout during unforeseen disruptions, plan strategies to adopt for your organization.
Set naming standards for your policies
The naming standard helps you to find policies and understand their purpose without opening them in the Azure admin portal. We recommend that you name your policy to show:
A Sequence Number
The cloud app(s) it applies to
Who it applies to
When it applies (if applicable)
Example; A policy to require MFA for marketing users accessing the Dynamics CRP app from external networks might be:
A descriptive name helps you to keep an overview of your Conditional Access implementation. The Sequence Number is helpful if you need to reference a policy in a conversation. For example, when you talk to an administrator on the phone, you can ask them to open policy CA01 to solve an issue.
Naming standards for emergency access controls
In addition to your active policies, implement disabled policies that act as secondary resilient access controls in outage or emergency scenarios. Your naming standard for the contingency policies should include:
ENABLE IN EMERGENCY at the beginning to make the name stand out among the other policies.
The name of disruption it should apply to.
An ordering sequence number to help the administrator to know in which order policies should be enabled.
The following name indicates that this policy is the first of four policies to enable if there's an MFA disruption:
EM01 - ENABLE IN EMERGENCY: MFA Disruption [1/4] - Exchange SharePoint: Require hybrid Azure AD join For VIP users.
Exclude countries from which you never expect a sign-in.
Azure active directory allows you to create named locations. Create a named location that includes all of the countries from which you would never expect a sign-in to occur. Then create a policy for All apps that blocks sign in from that named location. Be sure to exempt your administrators from this policy.
Plan your policy deployment
When new policies are ready for your environment, make sure that you review each policy before releasing it to avoid undesirable results.
When planning your Conditional Access policy solution, assess whether you need to create policies to achieve the following outcomes.
- Require MFA
- Respond to potentially compromised accounts
- Require managed devices
- Require approved client applications
- Block access
Common use cases to require MFA access:
Respond to potentially compromised accounts
With Conditional Access policies, you can implement automated responses to sign-ins by potentially compromised identities. The probability that an account is compromised is expressed in the form of risk levels. There are two risk levels calculated by Identity Protection: sign-in risk and user risk. The following three default policies that can be enabled.
Require managed devices
The proliferation of supported devices to access your cloud resources helps to improve the productivity of your users. You probably don't want certain resources in your environment to be accessed by devices with an unknown protection level. For those resources, require that users can only access them using a managed device.
Require approved client apps
Employees use their mobile devices for both personal and work tasks. For BYOD scenarios you must decide whether to manage the entire device or just the data on it. If managing only data and access, you can require approved cloud apps that can protect your corporate data. for example, you can require email only be accessed via Outlook mobile, and not via a generic mail program.
The option to block all access is powerful. It can be used, for example, when you are migrating an app to Azure AD, but are not ready for anyone to sign-in to it yet. Block access:
Overrides all other assignments for a user
Has the power to block your entire organization from signing on to your tenant
If you create a policy to block access for all users, be sure to exclude emergency access accounts, and consider excluding all administrators, from the policy.
Other common scenarios where you can block access for your users are:
Block certain network locations to access your cloud apps. You can use this policy to block certain countries where you know traffic shouldn't come from.
Azure AD supports legacy authentication. However, legacy authentication doesn't support MFA and many environments require it to address identity security. In this case, you can block apps using legacy authentication from accessing your tenant resources.
Build and test policies
At each stage of your deployment ensure that you're evaluating that results are as expected.
When new policies are ready, deploy them in phases in the production environment:
Provide internal change communication to end users.
Start with a small set of users and verify that the policy behaves as expected.
When you expand a policy to include more users, continue to exclude all administrators. Excluding administrators ensures that someone still has access to a policy if a change is required.
Apply a policy to all users only after it's thoroughly tested. Ensure you have at least one administrator account to which a policy doesn't apply.
Create test users
Create a set of test users that reflect the users in your production environment. Creating test users allows you to verify policies work as expected before you impact real users and potentially disrupt their access to apps and resources.
Some organizations have test tenants for this purpose. However, it can be difficult to recreate all conditions and apps in a test tenant to fully test the outcome of a policy.
Create a test plan
The test plan is important to have a comparison between the expected results and the actual results. You should always have an expectation before testing something. The following table outlines example test cases. Adjust the scenarios and expected results based on how your Conditional Access policies are configured.
|Require MFA when not at work||Authorized user signs into App while on a trusted location / work||User is not prompted to MFA|
|Require MFA when not at work||Authorized user signs into App while not on a trusted location / work||User is prompted to MFA and can sign in successfully|
|Require MFA (for admin)||Global Admin signs into App||Admin is prompted to MFA|
|Risky sign-ins||User signs into App using an unapproved browser||Admin is prompted to MFA|
|Device management||Authorized user attempts to sign in from an authorized device||Access Granted|
|Device management||Authorized user attempts to sign in from an unauthorized device||Access blocked|
|Password change for risky users||Authorized user attempts to sign in with compromised credentials (high risk sign in)||User is prompted to change password or access is blocked based on your policy|
Configure the test policy
In the Azure portal, you configure Conditional Access policies under Azure Active Directory > Security > Conditional Access.
If you want to learn more about how to create Conditional Access policies, see this example: Conditional Access policy to prompt for MFA when a user signs in to the Azure portal. This quickstart helps you to:
Become familiar with the user interface
Get a first impression of how Conditional Access works
Enable the policy in report-only mode
To assess the impact of your policy, start by enabling the policy in report-only mode. Report-only policies are evaluated during sign-in but grant controls and session controls aren't enforced. Once you save the policy in report-only mode, you can see the impact on real-time sign-ins in the sign-in logs. From the sign-in logs, select an event and navigate to the Report-only tab to see the result of each report-only policy.
Selecting the policy, you can also see how the assignments and access controls of the policy were evaluated using the Policy details screen. In order for a policy to apply to a sign-in, each of the configured assignments must be satisfied.
Understand the impact of your policies using the Insights and Reporting workbook
You can view the aggregate impact of your Conditional Access policies in the Insights and Reporting workbook. To access the workbook, you need an Azure Monitor subscription and you will need to stream your Sign-in logs to a Log Analytics workspace.
Simulate sign-ins using the what-if tool
Another way to validate your Conditional Access policy is by using the what-if tool, which simulates which policies would apply to a user signing in under hypothetical circumstances. Select the sign-in attributes you want to test (such as user, application, device platform, and location) and see which policies would apply.
While a simulated run gives you a good idea of the impact a Conditional Access policy has, it does not replace an actual test run.
Test your policy
Perform each test in your test plan with test users.
Ensure you test the exclusion criteria of a policy. For example, you may exclude a user or group from a policy that requires MFA. Test if the excluded users are prompted for MFA, because the combination of other policies might require MFA for those users.
Roll back policies
In case you need to roll back your newly implemented policies, use one or more of the following options:
- Disable the policy. Disabling a policy makes sure it does not apply when a user tries to sign in. You can always come back and enable the policy when you would like to use it.
- Exclude a user or group from a policy. If a user is unable to access the app, you can choose to exclude the user from the policy.
This option should be used sparingly, only in situations where the user is trusted. The user should be added back into the policy or group as soon as possible.
- Delete the policy. If the policy is no longer required, delete it.
Manage access to cloud apps
Use the following Manage options to control and manage your Conditional Access policies:
The location condition of a Conditional Access policy enables you to tie access controls settings to the network locations of your users. With Named Locations, you can create logical groupings of IP address ranges or countries and regions.
Custom controls redirect your users to a compatible service to satisfy authentication requirements outside of Azure AD. To satisfy this control, a user's browser is redirected to the external service, performs any required authentication, and is then redirected back to Azure AD. Azure AD verifies the response and, if the user was successfully authenticated or validated, the user continues in the Conditional Access flow.
Troubleshoot Conditional Access
When a user is having an issue with a Conditional Access policy, collect the following information to facilitate troubleshooting.
User principle Name
User display name
Operating system name
Time stamp (approximate is ok)
Client application type (browser vs client)
Correlation ID (this is unique to the sign-in)
If the user received a message with a More details link, they can collect most of this information for you.
Once you have collected the information, See the following resources:
Sign-in problems with Conditional Access – Understand unexpected sign-in outcomes related to Conditional Access using error messages and Azure AD sign-ins log.
Using the What-If tool - Understand why a policy was or wasn't applied to a user in a specific circumstance or if a policy would apply in a known state.