Azure AD Token Expiration Time Configuration and Best Practices

Author

Reads 726

Mother protecting eyes of children against digital content
Credit: pexels.com, Mother protecting eyes of children against digital content

Configuring Azure AD token expiration time is crucial for maintaining security and user experience. The default token expiration time is 1 hour, but this can be adjusted to meet specific needs.

The maximum token expiration time is 14 days, which can be set using the "tokenLifetime" parameter in the Azure AD configuration. This setting applies to all users and applications.

To avoid token expiration issues, it's essential to understand how Azure AD handles token renewal. The service automatically refreshes tokens before they expire, ensuring seamless access to resources.

However, token renewal can fail if the user's device is offline or has a poor internet connection. This is where the "tokenLifetime" parameter comes into play, allowing administrators to set a longer expiration time to accommodate such scenarios.

For more insights, see: Time Series Database Azure

Azure AD Token Expiration Time

Token expiration time is a crucial setting in Azure Active Directory (Azure AD) that determines how long a token remains valid before it expires. By default, tokens are valid for 90 days.

Credit: youtube.com, C# : How can I configure the expiration time of an Azure AD access token (using ADAL)?

You can change the token expiration time by creating a new token lifetime policy. To do this, you need to connect to your Azure AD tenant using the Azure AD PowerShell module. Once connected, you can check if there are any existing token lifetime policies defined.

If you want to change the default policy for new tenants, you can create a new policy with the desired settings. For example, you can set the refresh token inactivity to 90 days, and the single/multi-factor refresh token max age to "until-revoked".

Here's a list of the default token lifetime settings for new tenants:

If you have an existing old tenant, you can create a new policy that reflects the old default settings. For example, you can set the refresh token inactivity to 14 days, and the single/multi-factor refresh token max age to 90 days.

To update any existing organization default token lifetime policy, you can use the `Set-AzureADPolicy` cmdlet. This will update the policy with the new settings, but will not affect any existing tokens that have already been issued.

It's worth noting that you can also use the `Get-AzureADPolicy` cmdlet to view the existing token lifetime policies and settings. This can be useful for troubleshooting or auditing purposes.

See what others are reading: How to Update Azure Ad Connect

Manage Policies

Credit: youtube.com, Azue AD Token Lifespan Increase || Aztechs Academy

You can use the following cmdlets to manage policies: New-MgPolicyTokenLifetimePolicy creates a new policy, Get-MgPolicyTokenLifetimePolicy gets all token lifetime policies or a specified policy, Update-MgPolicyTokenLifetimePolicy updates an existing policy, and Remove-MgPolicyTokenLifetimePolicy deletes the specified policy.

These cmdlets are useful for managing token lifetime policies, which can be set for access, SAML, and ID tokens. You can set token lifetime policies using the New-MgPolicyTokenLifetimePolicy cmdlet.

To link a policy to an application, use the New-MgApplicationTokenLifetimePolicyByRef cmdlet. To get the policies assigned to an application, use the Get-MgApplicationTokenLifetimePolicyByRef cmdlet. To remove a policy from an application, use the Remove-MgApplicationTokenLifetimePolicyByRef cmdlet.

These cmdlets are part of the Azure AD management API and can be used to manage token lifetime policies for your applications.

Here is a summary of the cmdlets:

Configuration Options

Azure AD supports configurable token lifetimes, which can be set to a longer lifetime than the default 60-90 minutes. This can be achieved through a token lifetime policy, which is a type of policy object that contains token lifetime rules.

Credit: youtube.com, Microsoft API - Get Access Token and Refresh Token

The default lifetime value can be modified to suit organizational needs, but it's essential to note that all new access tokens will respect the new value. This means that it's not possible to set a new value for clients for non-CAE compatible clients and for CAE compatible clients on the other hand.

Token lifetime policies can be created via PowerShell, and they can be applied either by default to all applications or to a specific application. The creation of a token lifetime policy is done via PowerShell today.

To modify the default token lifetime, you'll need to define a token policy and apply it to the desired applications. This can be done using the following properties:

It's worth noting that creating a token lifetime policy with a new default lifetime for the organization works, but increasing token lifetime in this manner is not something to do on a whim. It would be better to assign a token lifetime policy only to the apps that need to use extended token lifetimes.

Best Practices and Control

Credit: youtube.com, ID Tokens VS Access Tokens: What's the Difference?

To control session lifetimes, you should use conditional access policies to impose a sign-in frequency based on populations, services, and context.

Using conditional access policies allows you to tailor your sign-in frequency to specific groups of users or administrators, and even to different services and contexts.

Impose a default sign-in frequency to ensure that users are periodically required to sign in, even if they're not using conditional access policies.

This helps prevent long sessions that could potentially expose your organization to security risks.

Leave the Keep me sign-in option available for users, but make them aware of its implications.

This allows users to choose whether or not to stay signed in, while still educating them about the potential security risks.

Enable Continuous Access Evaluation, using IP named locations instead of Trusted IP.

This feature helps to continuously evaluate the user's access and session status, even after they've initially signed in.

For more insights, see: Azure Devops Personal Access Token

Credit: youtube.com, What are Refresh Tokens?! and...How to Use Them Securely

Disable resilience defaults durations for the most sensitive accesses to minimize the risk of unauthorized access.

Here are the best practices to control session lifetimes in a concise list:

  1. Use conditional access policies to impose a sign-in frequency based on populations (users vs. admins), services, and context
  2. Impose a default sign-in frequency
  3. Leave the Keep me sign-in option available for users (but make users aware)
  4. Enable Continuous Access Evaluation (use IP named locations and not Trusted IP)
  5. Disable resilience defaults durations for the most sensitive accesses

Azure AD PowerShell and API

Azure AD PowerShell and API can be used to manage Azure Active Directory, including token expiration times.

You can use the Azure AD PowerShell module to check the token expiration time for a user. For example, you can use the Get-AzureADUser cmdlet to retrieve a user's token expiration time.

Azure AD API can also be used to manage token expiration times. The Azure AD Graph API, for instance, allows you to retrieve a user's token expiration time using the GET /users/{id}/tokenProperties request.

Azure AD PowerShell and API can be used to configure token renewal policies. For example, you can use the Set-AzureADPolicy cmdlet to configure a token renewal policy using Azure AD PowerShell.

Frequently Asked Questions

What is the default timeout for Azure tokens?

The default timeout for Azure tokens is 1 hour (60 minutes). You can adjust this time to a minimum of 5 minutes or a maximum of 24 hours (1,440 minutes).

Rosemary Boyer

Writer

Rosemary Boyer is a skilled writer with a passion for crafting engaging and informative content. With a focus on technical and educational topics, she has established herself as a reliable voice in the industry. Her writing has been featured in a variety of publications, covering subjects such as CSS Precedence, where she breaks down complex concepts into clear and concise language.

Love What You Read? Stay Updated!

Join our community for insights, tips, and more.