OAuth 2.0 connections in credential manager - process details and flows
Article
APPLIES TO: All API Management tiers
This article provides details about the process flows for managing OAuth 2.0 connections using credential manager in Azure API Management. The process flows are divided into two parts: management and runtime.
The management part of connections in credential manager takes care of setting up and configuring a credential provider for OAuth 2.0 tokens, enabling the consent flow for the provider, and setting up one or more connections to the credential provider for access to the credentials.
The following image summarizes the process flow for creating a connection in API Management that uses the authorization code grant type.
Step
Description
1
Client sends a request to create a credential provider
2
Credential provider is created, and a response is sent back
3
Client sends a request to create a connection
4
Connection is created, and a response is sent back with the information that the connection isn't "connected"
5
Client sends a request to retrieve a login URL to start the OAuth 2.0 consent at the credential provider. The request includes a post-redirect URL to be used in the last step
6
Response is returned with a login URL that should be used to start the consent flow.
7
Client opens a browser with the login URL that was provided in the previous step. The browser is redirected to the credential provider's OAuth 2.0 consent flow
8
After the consent is approved, the browser is redirected with an authorization code to the redirect URL configured at the credential provider
9
API Management uses the authorization code to fetch access and refresh tokens
10
API Management receives the tokens and encrypts them
11
API Management redirects to the provided URL from step 5
Credential provider
When configuring your credential provider, you can choose between different OAuth providers and grant types (authorization code or client credential). Each provider requires specific configurations. Important things to keep in mind:
A credential provider configuration can only have one grant type.
With the Generic OAuth 2.0 provider, other identity providers that support the standards of OAuth 2.0 flow can be used.
When you configure a credential provider, behind the scenes credential manager creates a credential store that is used to cache the provider's OAuth 2.0 access tokens and refresh tokens.
Connection to a credential provider
To access and use tokens for a provider, client apps need a connection to the credential provider. A given connection is permitted by access policies based on Microsoft Entra ID identities. You can configure multiple connections for a provider.
The process of configuring a connection differs based on the configured grant and is specific to the credential provider configuration. For example, if you want to configure Microsoft Entra ID to use both grant types, two credential provider configurations are needed. The following table summarizes the two grant types.
Grant type
Description
Authorization code
Bound to a user context, meaning a user needs to consent to the connection. As long as the refresh token is valid, API Management can retrieve new access and refresh tokens. If the refresh token becomes invalid, the user needs to reauthorize. All credential providers support authorization code. Learn more
Client credentials
Isn't bound to a user and is often used in application-to-application scenarios. No consent is required for client credentials grant type, and the connection doesn't become invalid. Learn more
Consent
For connections based on the authorization code grant type, you must authenticate to the provider and consent to authorization. After successful login and authorization by the credential provider, the provider returns valid access and refresh tokens, which are encrypted and saved by API Management.
Access policy
You configure one or more access policies for each connection. The access policies determine which Microsoft Entra ID identities can gain access to your credentials at runtime. Connections currently support access using service principals, your API Management instance's identity, users, and groups.
Identity
Description
Benefits
Considerations
Service principal
Identity whose tokens can be used to authenticate and grant access to specific Azure resources, when an organization is using Microsoft Entra ID. By using a service principal, organizations avoid creating fictitious users to manage authentication when they need to access a resource. A service principal is a Microsoft Entra identity that represents a registered Microsoft Entra application.
Permits more tightly scoped access to connection and user delegation scenarios. Isn't tied to specific API Management instance. Relies on Microsoft Entra ID for permission enforcement.
Managed identity <Your API Management instance name>
This option corresponds to a managed identity tied to your API Management instance.
By default, access is provided to the system-assigned managed identity for the corresponding API management instance.
Identity is tied to your API Management instance. Anyone with Contributor access to API Management instance can access any connection granting managed identity permissions.
Users or groups
Users or groups in your Microsoft Entra ID tenant.
Allows you to limit access to specific users or groups of users.
Requires that users have a Microsoft Entra ID account.
Runtime of connections
The runtime part requires a backend OAuth 2.0 API to be configured with the get-authorization-context policy. At runtime, the policy fetches and stores access and refresh tokens from the credential store that API Management set up for the provider. When a call comes into API Management, and the get-authorization-context policy is executed, it first validates if the existing authorization token is valid. If the authorization token has expired, API Management uses an OAuth 2.0 flow to refresh the stored tokens from the credential provider. Then the access token is used to authorize access to the backend service.
During the policy execution, access to the tokens is also validated using access policies.
The following image shows an example process flow to fetch and store authorization and refresh tokens based on a connection that uses the authorization code grant type. After the tokens have been retrieved, a call is made to the backend API.
If the access token has expired but the refresh token is valid, API Management tries to fetch new access and refresh tokens from the configured credential provider
4
The credential provider returns both an access token and a refresh token, which are encrypted and saved to API Management
5
After the tokens have been retrieved, the access token is attached using the set-header policy as an authorization header to the outgoing request to the backend API