OIDC With Azure
How to authenticate the env0 runner using Azure and OIDC
This guide is to help you connect to Azure with OIDC, instead of using a Service Principal.
Overview
This guide will show you how to create an Azure AD App, configure a Federated Credential, and configure env0 to utilize OIDC. The federated credential within the Azure AD app will be configured to accept env0's OIDC token. Refer to OIDC Integrations for more background on env0's OIDC configuration.
Azure AD App + Federated Credential
The Azure AD App will be configured with a Federated Credential in order to accept env0 OIDC token. Using the Azure Portal:
- Microsoft Entra ID > App registrations > "+ New Registration"
- Enter Name: e.g. "env0 OIDC app"
- Select Supported account types if you're unsure, choose âSingle tenantâ
- Skip Redirect URI
- Register the app.
- Note your Application (client) ID (
ARM_CLIENT_ID
) and Directory (tenant) ID (ARM_TENANT_ID
)ARM_TENANT_ID=f3450d00-1632-47b8-ab1b-c7c1617ef6cd
ARM_CLIENT_ID=e701f066-c866-4321-9adc-1089dcae9ff5
- Under the âenv0 OIDC appâ > âCertificates and Secretsâ > âFederated credentialsâ
- â+ Add credentialâ
- Federated Credential Scenario - Other issuer
- Issuer -
https://login.app.env0.com/
- Subject Identifier -
auth0|xxxxxx
(see the section below on âRetrieving your Subject Identifierâ) - Name - enter a name (e.g. "env0 OIDC")
- Audience -
https://prod.env0.com
- For the Azure Provider in Terraform, we need to specify the following variables:
ARM_TENANT_ID
- you can find the value in your app registration summary (âenv0 OIDC appâ) under âDirectory (tenant) IDâARM_CLIENT_ID
- you can find the value in your app registration summary (âenv0 OIDC appâ) under âApplication (client) IDâARM_SUBSCRIPTION_ID
- You can retrieve the Subscription ID from the Azure Subscription, or in a Resource Group that you want to use.
Azure App AD App Permissions
In order for Terraform to be able to deploy and manage the resources, we need to associate your Azure AD App with your Subscription or Resource Group
- In this example, I will give the âenv0 OIDC appâ the âContributorâ role in my âsales-acme-demoâ resource group. This means that env0 will only be able to create and manage resources within this resource group.
- Go to the Resource Group (âsales-acme-demoâ) > Access Control (IAM)
- Click on â+ Addâ > âAdd role assignmentâ
- Select a role (the level of privilege to give to Terraform) - in this case, we choose âContributorâ and hit âNextâ
- Assign access to âUser, group, or service principalâ
- Select a member by â+ Select Membersâ
- Search for âenv0 OIDC appâ and hit âSelectâ
- Hit "Review + assign"
Configure env0 OIDC Credential
Go to the organization's credentials page and create a new deployment credential. Select Azure OIDC
type and enter the following fields:
Subscription ID
- Azure subscription idTenant ID
- Azure tenant idClient ID
- Azure client id
Azure Provider Version
Make sure you use a version of the Azure provider greater than 3.7.0.
OIDC did not work for â=3.7.0â
Assign your Credential in your Project
After creating your Organization Credential - don't forget to go into your Project Settings to use the OIDC credential you just created.
Deploying to multiple Azure Subscriptions
Sometimes you want to be able to deploy to multiple Azure Subscriptions in one Terraform workspace. In Terraform / OpenTofu, you can specify multiple azure provider blocks in order to target mutliple subscriptions, see example below:
provider "azurerm" {
features {}
use_oidc = true
//subscription_id = "b48787a1-7145-425f-99af-62cde6c50e31" (optional)
//env0 will use the subscription ID in defined in the Azure OIDC project credential configuration
}
provider "azurerm" {
alias = "test"
features {}
use_oidc = true
subscription_id = var.second_subscription
}
variable "second_subscription" {
type = string
default = "3ef32f99-33d5-4a4f-bf9c-8a3ebb2b0144"
}
resource "azurerm_resource_group" "example" {
name = "env0-example-rg"
location = "eastus2"
}
resource "azurerm_resource_group" "second" {
provider = azurerm.test
name = "env0-example-second-rg"
location = "eastus2"
}
By simply, ensuring that the same App Registration created earlier ("env0 OIDC App") has permissions in the both subscriptions; you can utilize one set of credentials to target multiple subscriptions.
Updated 4 months ago