top of page
Writer's pictureSzymon Rożek

Azure Api Management Oauth 2.0 authorization - Azure APIM #1

Azure Api Management is one of the most popular resources available in Azure. In today's post, I'd like to present a simple way to effectively handle APIs and offer OAuth2.0 authorization options to users of our APIs.

Github repository with solution: click here



Preparations

In addition to the prerequisites mentioned earlier, we must also include the API permission for our deployment service principal as shown in the image below. This permission allows the service principal to create objects for Entra Id. In addition I am attaching Terraform documentation for that module azuread_application.

Service principal permission

APIM Deployment

Initially, the APIM resource needs to be implemented. I have developed a Terraform module specifically for this task, which comes with an app registration as a standard feature. This setup enables us to securely access our APIs through OAuth 2.0 with enhanced functionality.



Kindly wait as it could require up to 40 minutes to generate this resource. Furthermore, an application registration will be established in Azure Entra Id. The subsequent task involves generating a secret that will enable us to create the access token:

app registration in entra Id
app registration in entra Id

Lets save the secret and client Id on that app registration, we will need to use it later on.

app registration client id
app registration client id

Apim Api deployment


As you are aware, this resource is essential for managing incoming and outgoing traffic for various services. For example, we will set up a logic app with an HTTP trigger and then deploy a new endpoint to APIM.

Here is the implementation of inbound_api.tf that deploys a new API to the APIM instance and configures a logic app as its backend.



As we shift our pipelines towards sustainability, we should be able to find a new endpoint in the Azure API Management service.

logic app api
logic app api

Furthermore, we can verify the inbound policies, where token validation is enforced; otherwise, a 401 HTTP response status message is returned.

Api inbound policy
Api inbound policy

Postman verification

In order to verify if we can access our API and endpoints exclusively through OAuth 2.0 authorization, we can initiate a new request to our endpoint and set up the necessary authorization. To achieve this, the following steps need to be taken:

Type of authorization
Type of authorization

data for authorization
data for authorization

How to fill the data

  • Access Token URL -> https://login.microsoftonline.com/{Your_tenant_id}/oauth2/v2.0/token

  • Client ID -> Client Id

  • Client Secret -> Client Secret

  • Scope -> api://{azure_api_management_sample_api.application_name}/.default

Results - without any kind of token:

postman call without token
postman call without token

With token generated based on the values listed above:

postman call with token
postman call with token
logic app trigger
logic app trigger

Furthermore, we can observe that our logic app was successfully triggered! Success :)


Summary

This article serves as a comprehensive guide to effectively managing APIs in Azure API Management (APIM) and implementing OAuth 2.0 authorization for users. Additionally, it illustrates the process of authenticating API access through OAuth 2.0 using Postman, detailing the necessary steps such as configuring the access token URL, client ID, and secret. It wraps up by encouraging readers to share the article if they find it beneficial.

If you like the article share it! Ill be very glad

Recent Posts

See All

Azure setup - prerequisites

This article is for everyone who wants to set up an Azure environment to work with my use cases and sample Azure architectures. Besides,...

コメント


bottom of page