layout | page_title | description |
---|---|---|
azuredevops |
Provider: Azure DevOps |
The Azure DevOps provider is used to interact with Azure DevOps organization resources. |
The Azure DevOps provider can be used to configure Azure DevOps project in Microsoft Azure using Azure DevOps Service REST API
Use the navigation to the left to read about the available resources.
Interested in the provider's latest features, or want to make sure you're up to date? Check out the changelog for version information and release notes.
terraform {
required_providers {
azuredevops = {
source = "microsoft/azuredevops"
version = ">= 0.1.0"
}
}
}
resource "azuredevops_project" "project" {
name = "Project Name"
description = "Project Description"
}
Authentication may be accomplished using an Azure AD service principal if your organization is connected to Azure AD, or by a personal access token.
The provider will use the first available authentication method that is available. They are discovered in the following order:
- Personal Access Token
- With
use_oidc = true
- OIDC Token
- OIDC Token File Path
- OIDC Token Request URL
- TFC Cloud Workload Identity Token
- Client Certificate Path
- Client Certificate
- Client Secret Path
- Client Secret
- With
use_msi = true
- Managed Service Identity
The OIDC service principal authentication methods allow for secure passwordless authentication from Terraform Cloud & GitHub Actions.
- Authenticating to a Service Principal with Manage Identity
- Authenticating to a Service Principal with a Client Certificate
- Authenticating to a Service Principal with a Client Secret
- Authenticating to a Service Principal with an OIDC Token
- Authenticating using a Personal Access Token
The following arguments are supported in the provider
block:
-
org_service_url
- (Required) This is the Azure DevOps organization url. It can also be sourced from theAZDO_ORG_SERVICE_URL
environment variable. -
personal_access_token
- This is the Azure DevOps organization personal access token. The account corresponding to the token will need "owner" privileges for this organization. It can also be sourced from theAZDO_PERSONAL_ACCESS_TOKEN
environment variable. -
client_id
- The client id used when authenticating to a service principal or the principal id when authenticating with a user specified managed service identity. It can also be sourced from theARM_CLIENT_ID
environment variable. -
tenant_id
- The tenant id used when authenticating to a service principal. It can also be sourced from theARM_TENANT_ID
environment variable. -
client_id_plan
- The client id used when authenticating to a service principal using the Terraform Cloud workload identity token during a plan operation in Terraform Cloud.client_id
may be used if the id is the same for plan & apply. It can also be sourced from theARM_CLIENT_ID_PLAN
environment variable. -
client_id_apply
- The client id used when authenticating to a service principal using the Terraform Cloud workload identity token during an apply operation in Terraform Cloud.client_id
may be used if the id is the same for plan & apply. It can also be sourced from theARM_CLIENT_ID_APPLY
environment variable. -
tenant_id_plan
- The tenant id used when authenticating to a service principal using the Terraform Cloud workload identity token during a plan operation in Terraform Cloud.tenant_id
may be used if the id is the same for plan & apply. It can also be sourced from theARM_TENANT_ID_PLAN
environment variable. -
tenant_id_apply
- The tenant id used when authenticating to a service principal using the Terraform Cloud workload identity token during an apply operation in Terraform Cloud.tenant_id
may be used if the id is the same for plan & apply. It can also be sourced from theARM_TENANT_ID_APPLY
environment variable. -
client_secret
- The client secret used to authenticate to a service principal. It can also be sourced from theARM_CLIENT_SECRET
environment variable. -
client_secret_path
- The path to a file containing a client secret to authenticate to a service principal. It can also be sourced from theARM_CLIENT_SECRET_PATH
environment variable. -
oidc_audience
- Specifies the oidc audience to request when using anoidc_request_url
, most commonly with GitHub Actions. It can also be sourced from theARM_OIDC_AUDIENCE
environment variable. -
oidc_request_token
- The bearer token for the request to the OIDC provider. For use when authenticating as a Service Principal using OpenID Connect. It can also be sourced from theARM_OIDC_REQUEST_TOKEN
orACTIONS_ID_TOKEN_REQUEST_TOKEN
environment variables. -
oidc_request_url
- The URL for the OIDC provider from which to request an ID token. For use when authenticating as a Service Principal using OpenID Connect. It can also be sourced from theARM_OIDC_REQUEST_URL
orACTIONS_ID_TOKEN_REQUEST_URL
environment variables. -
oidc_tfc_tag
- Terraform Cloud dynamic credential provider tag. It can also be sourced from theARM_OIDC_TFC_TAG
environment variable. -
oidc_token
- An OIDC token to authenticate to a service principal. It can also be sourced from theARM_OIDC_TOKEN
environment variable. -
oidc_token_file_path
- The path to a file containing nn OIDC token to authenticate to a service principal. It can also be sourced from theAZDO_TOKEN_PATH
environment variable. -
oidc_github_actions
- Boolean, set to true to use a GitHub Actions OIDC token to authenticate to a service principal. It can also be sourced from theARM_OIDC_GITHUB_ACTIONS
environment variable. -
oidc_github_actions_audience
- Custom audience for the GitHub Actions OIDC token. It can also be sourced from theARM_OIDC_GITHUB_ACTIONS_AUDIENCE
environment variable. -
use_oidc
- Boolean, enables OIDC auth methods. It can also be sourced from theARM_USE_OIDC
environment variable. -
use_msi
- Boolean, enables authentication with a Managed Service Identity in Azure. It can also be sourced from theARM_USE_MSI
environment variable. -
client_certificate_path
- The path to a file containing a certificate to authenticate to a service principal, typically a .pfx file. It can also be sourced from theARM_CLIENT_CERTIFICATE_PATH
environment variable. -
client_certificate
- A base64 encoded certificate to authentiate to a service principal. It can also be sourced from theARM_CLIENT_CERTIFICATE
environment variable. -
client_certificate_password
- This is the password associated with a certificate provided byclient_certificate_path
orclient_certificate
. It can also be sourced from theARM_CLIENT_CERTIFICATE_PASSWORD
environment variable.