Bicep resource definition
The connections resource type can be deployed with operations that target:
For a list of changed properties in each API version, see change log.
To create a Microsoft.Web/connections resource, add the following Bicep to your template.
resource symbolicname 'Microsoft.Web/connections@2016-06-01' = {
  scope: resourceSymbolicName or scope
  etag: 'string'
  location: 'string'
  name: 'string'
  properties: {
    api: {
      brandColor: 'string'
      description: 'string'
      displayName: 'string'
      iconUri: 'string'
      id: 'string'
      name: 'string'
      swagger: any(...)
      type: 'string'
    }
    changedTime: 'string'
    createdTime: 'string'
    customParameterValues: {
      {customized property}: 'string'
    }
    displayName: 'string'
    nonSecretParameterValues: {
      {customized property}: 'string'
    }
    parameterValues: {
      {customized property}: 'string'
    }
    statuses: [
      {
        error: {
          etag: 'string'
          location: 'string'
          properties: {
            code: 'string'
            message: 'string'
          }
          tags: {
            {customized property}: 'string'
          }
        }
        status: 'string'
        target: 'string'
      }
    ]
    testLinks: [
      {
        method: 'string'
        requestUri: 'string'
      }
    ]
  }
  tags: {
    {customized property}: 'string'
  }
}
Property Values
Microsoft.Web/connections
| Name | Description | Value | 
| etag | Resource ETag | string | 
| location | Resource location | string | 
| name | The resource name | string (required) | 
| properties |  | ApiConnectionDefinitionProperties | 
| scope | Use when creating a resource at a scope that is different than the deployment scope. | Set this property to the symbolic name of a resource to apply the extension resource. | 
| tags | Resource tags | Dictionary of tag names and values. See Tags in templates | 
ApiConnectionDefinitionProperties
ApiConnectionDefinitionPropertiesCustomParameterValues
ApiConnectionDefinitionPropertiesNonSecretParameterValues
ApiConnectionDefinitionPropertiesParameterValues
ApiConnectionTestLink
| Name | Description | Value | 
| method | HTTP Method | string | 
| requestUri | Test link request URI | string | 
ApiReference
| Name | Description | Value | 
| brandColor | Brand color | string | 
| description | The custom API description | string | 
| displayName | The display name | string | 
| iconUri | The icon URI | string | 
| id | Resource reference id | string | 
| name | The name of the API | string | 
| swagger | The JSON representation of the swagger | any | 
| type | Resource reference type | string | 
ConnectionError
ConnectionErrorProperties
| Name | Description | Value | 
| code | Code of the status | string | 
| message | Description of the status | string | 
ConnectionStatusDefinition
| Name | Description | Value | 
| error | Connection error | ConnectionError | 
| status | The gateway status | string | 
| target | Target of the error | string | 
Usage Examples
Azure Quickstart Samples
The following Azure Quickstart templates contain Bicep samples for deploying this resource type.
| Bicep File | Description | 
| Azure Logic Apps - AS2 Send Receive | Creates integration accounts for two partners, Contoso and Fabrikam, including the artifacts for partners and agreements. The template also creates logic apps between Fabrikam Sales and Contoso to demonstrate synchronous AS2 Send Receive. The template also creates logic apps between Fabrikam Finance and Contoso, which demonstrate asynchronous AS2 Send Receive. | 
| Copy FTP files to Azure Blob logic app | This template allows you to create a Logic app triggers on files in an FTP server and copies them to an Azure Blob container. You can add an additional triggers or actions to customize it to your needs. | 
| Retrieve Azure Storage access keys in ARM template | This template will create a Storage account, after which it will create a API connection by dynamically retrieving the primary key of the Storage account. The API connection is then used in a Logic App as a trigger polling for blob changes. | 
 
 
ARM template resource definition
The connections resource type can be deployed with operations that target:
For a list of changed properties in each API version, see change log.
To create a Microsoft.Web/connections resource, add the following JSON to your template.
{
  "type": "Microsoft.Web/connections",
  "apiVersion": "2016-06-01",
  "name": "string",
  "etag": "string",
  "location": "string",
  "properties": {
    "api": {
      "brandColor": "string",
      "description": "string",
      "displayName": "string",
      "iconUri": "string",
      "id": "string",
      "name": "string",
      "swagger": {},
      "type": "string"
    },
    "changedTime": "string",
    "createdTime": "string",
    "customParameterValues": {
      "{customized property}": "string"
    },
    "displayName": "string",
    "nonSecretParameterValues": {
      "{customized property}": "string"
    },
    "parameterValues": {
      "{customized property}": "string"
    },
    "statuses": [
      {
        "error": {
          "etag": "string",
          "location": "string",
          "properties": {
            "code": "string",
            "message": "string"
          },
          "tags": {
            "{customized property}": "string"
          }
        },
        "status": "string",
        "target": "string"
      }
    ],
    "testLinks": [
      {
        "method": "string",
        "requestUri": "string"
      }
    ]
  },
  "tags": {
    "{customized property}": "string"
  }
}
Property Values
Microsoft.Web/connections
| Name | Description | Value | 
| apiVersion | The api version | '2016-06-01' | 
| etag | Resource ETag | string | 
| location | Resource location | string | 
| name | The resource name | string (required) | 
| properties |  | ApiConnectionDefinitionProperties | 
| tags | Resource tags | Dictionary of tag names and values. See Tags in templates | 
| type | The resource type | 'Microsoft.Web/connections' | 
ApiConnectionDefinitionProperties
ApiConnectionDefinitionPropertiesCustomParameterValues
ApiConnectionDefinitionPropertiesNonSecretParameterValues
ApiConnectionDefinitionPropertiesParameterValues
ApiConnectionTestLink
| Name | Description | Value | 
| method | HTTP Method | string | 
| requestUri | Test link request URI | string | 
ApiReference
| Name | Description | Value | 
| brandColor | Brand color | string | 
| description | The custom API description | string | 
| displayName | The display name | string | 
| iconUri | The icon URI | string | 
| id | Resource reference id | string | 
| name | The name of the API | string | 
| swagger | The JSON representation of the swagger | any | 
| type | Resource reference type | string | 
ConnectionError
ConnectionErrorProperties
| Name | Description | Value | 
| code | Code of the status | string | 
| message | Description of the status | string | 
ConnectionStatusDefinition
| Name | Description | Value | 
| error | Connection error | ConnectionError | 
| status | The gateway status | string | 
| target | Target of the error | string | 
Usage Examples
Azure Quickstart Templates
The following Azure Quickstart templates deploy this resource type.
| Template | Description | 
| Alert to queue with Logic app 
 
  | This template allows you to create a Logic app that has a webhook. When the Logic app is triggered, it will add the payload you pass to an Azure Storage queue that you specify. You can add this webhook to an Azure Alert and then whenever the Alert fires, you'll get that item in the queue. | 
| Alert to Slack with Logic app 
 
  | This template allows you to create a Logic app that has a webhook to be used from an Azure Alert. When the Alert is triggered, it will post a message to a slack channel that you specify. You need to have a slack account to use this template. | 
| Alert to text message with Logic app 
 
  | This template allows you to create a Logic app that has a webhook to be used from an Azure Alert. When the Alert is triggered, it will send you a text message with the details of the alert. It uses the go.gl URL shortening service to include a link to the portal to see the resource. | 
| Azure Logic Apps - AS2 Send Receive 
 
  | Creates integration accounts for two partners, Contoso and Fabrikam, including the artifacts for partners and agreements. The template also creates logic apps between Fabrikam Sales and Contoso to demonstrate synchronous AS2 Send Receive. The template also creates logic apps between Fabrikam Finance and Contoso, which demonstrate asynchronous AS2 Send Receive. | 
| Azure Logic Apps - B2B Disaster Recovery replication 
 
  | Creates replication Logic Apps for AS2 MIC, generated and received X12 control numbers. Each Logic App's trigger points to a primary site integration account. Each Logic App's action points to a secondary site integration account. | 
| Copy FTP files to Azure Blob logic app 
 
  | This template allows you to create a Logic app triggers on files in an FTP server and copies them to an Azure Blob container. You can add an additional triggers or actions to customize it to your needs. | 
| Correlating messages over Logic Apps using Service Bus 
 
  | which shows how we can correlate messages over Logic Apps using Azure Service Bus | 
| Deploy a sample logic app, to use as Entitlement Management custom extensions 
 
  | This template creates a simple logic app with all the authorization policy settings, service now connetion to create tickets and schema to http trigger that is needed by Entitlement Management custom extension API. | 
| Logic App to email detailed backup reports 
 
  | Create a Logic App to send reports on backup instances, usage, jobs, policies, policy adherence, and optimization opportunities via email. | 
| Logic App to email reports on backup and restore jobs 
 
  | Create a Logic App to send reports on your backup and restore jobs via email | 
| Logic App to email reports on backup cost optimizmation 
 
  | This template deploys a Logic App that sends periodic reports on inactive backup resources, possible backup schedule optimizations and possible backup retention optimizations, to a specified set of email addresses. | 
| Logic App to email reports on backup instances 
 
  | Create a Logic App to send reports on backup instances protected using Azure Backup via email | 
| Logic App to email reports on backup policies 
 
  | Create a Logic App to send reports on your backup policies via email | 
| Logic App to email reports on backup policy adherence 
 
  | Create a Logic App to send reports on backup policy adherence of your backup instances via email | 
| Logic App to email reports on your Azure Backup billing 
 
  | This template deploys a Logic App that sends periodic reports on key backup billing parameters (protected instances and backup cloud storage consumed) at a billing-entity level, to a specified set of email addresses. | 
| Logic App to email summary reports on backups 
 
  | Create a Logic App to send summary reports on your backups via email. | 
| Retrieve Azure Storage access keys in ARM template 
 
  | This template will create a Storage account, after which it will create a API connection by dynamically retrieving the primary key of the Storage account. The API connection is then used in a Logic App as a trigger polling for blob changes. | 
| Run a SQL stored procedure on a schedule via a logic app 
 
  | This template allows you to create a Logic App that will run a SQL stored procedure on schedule. Any arguments for the procedure can be put into the body section of the template. | 
| Send email with Logic app 
 
  | This template allows you to create a Logic app that sends an email. You can add an additional triggers or actions to customize it to your needs. | 
 
 
The connections resource type can be deployed with operations that target:
For a list of changed properties in each API version, see change log.
To create a Microsoft.Web/connections resource, add the following Terraform to your template.
resource "azapi_resource" "symbolicname" {
  type = "Microsoft.Web/connections@2016-06-01"
  name = "string"
  parent_id = "string"
  location = "string"
  tags = {
    {customized property} = "string"
  }
  body = {
    etag = "string"
    properties = {
      api = {
        brandColor = "string"
        description = "string"
        displayName = "string"
        iconUri = "string"
        id = "string"
        name = "string"
        swagger = ?
        type = "string"
      }
      changedTime = "string"
      createdTime = "string"
      customParameterValues = {
        {customized property} = "string"
      }
      displayName = "string"
      nonSecretParameterValues = {
        {customized property} = "string"
      }
      parameterValues = {
        {customized property} = "string"
      }
      statuses = [
        {
          error = {
            etag = "string"
            location = "string"
            properties = {
              code = "string"
              message = "string"
            }
            tags = {
              {customized property} = "string"
            }
          }
          status = "string"
          target = "string"
        }
      ]
      testLinks = [
        {
          method = "string"
          requestUri = "string"
        }
      ]
    }
  }
}
Property Values
Microsoft.Web/connections
| Name | Description | Value | 
| etag | Resource ETag | string | 
| location | Resource location | string | 
| name | The resource name | string (required) | 
| parent_id | The ID of the resource to apply this extension resource to. | string (required) | 
| properties |  | ApiConnectionDefinitionProperties | 
| tags | Resource tags | Dictionary of tag names and values. | 
| type | The resource type | "Microsoft.Web/connections@2016-06-01" | 
ApiConnectionDefinitionProperties
ApiConnectionDefinitionPropertiesCustomParameterValues
ApiConnectionDefinitionPropertiesNonSecretParameterValues
ApiConnectionDefinitionPropertiesParameterValues
ApiConnectionTestLink
| Name | Description | Value | 
| method | HTTP Method | string | 
| requestUri | Test link request URI | string | 
ApiReference
| Name | Description | Value | 
| brandColor | Brand color | string | 
| description | The custom API description | string | 
| displayName | The display name | string | 
| iconUri | The icon URI | string | 
| id | Resource reference id | string | 
| name | The name of the API | string | 
| swagger | The JSON representation of the swagger | any | 
| type | Resource reference type | string | 
ConnectionError
ConnectionErrorProperties
| Name | Description | Value | 
| code | Code of the status | string | 
| message | Description of the status | string | 
ConnectionStatusDefinition
| Name | Description | Value | 
| error | Connection error | ConnectionError | 
| status | The gateway status | string | 
| target | Target of the error | string | 
Usage Examples
A basic example of deploying API Connection.
terraform {
  required_providers {
    azapi = {
      source = "Azure/azapi"
    }
  }
}
provider "azapi" {
  skip_provider_registration = false
}
provider "azurerm" {
  features {
  }
}
variable "resource_name" {
  type    = string
  default = "acctest0001"
}
variable "location" {
  type    = string
  default = "eastus"
}
resource "azapi_resource" "resourceGroup" {
  type     = "Microsoft.Resources/resourceGroups@2020-06-01"
  name     = var.resource_name
  location = var.location
}
resource "azapi_resource" "workflows" {
  type      = "Microsoft.Logic/workflows@2019-05-01"
  parent_id = azapi_resource.resourceGroup.id
  name      = var.resource_name
  location  = var.location
  body = {
    identity = {
      type                   = "None"
      userAssignedIdentities = null
    }
    properties = {
      definition = {
        "$schema"      = "https://schema.management.azure.com/providers/Microsoft.Logic/schemas/2016-06-01/workflowdefinition.json#"
        contentVersion = "1.0.0.0"
      }
      state = "Enabled"
    }
  }
  schema_validation_enabled = false
  response_export_values    = ["*"]
}
resource "azapi_resource" "namespaces" {
  type      = "Microsoft.ServiceBus/namespaces@2022-10-01-preview"
  parent_id = azapi_resource.resourceGroup.id
  name      = var.resource_name
  location  = var.location
  body = {
    identity = {
      type                   = "None"
      userAssignedIdentities = null
    }
    properties = {
      disableLocalAuth           = false
      minimumTlsVersion          = "1.2"
      premiumMessagingPartitions = 0
      publicNetworkAccess        = "Enabled"
    }
    sku = {
      capacity = 0
      name     = "Basic"
      tier     = "Basic"
    }
  }
  schema_validation_enabled = false
  response_export_values    = ["*"]
}
data "azurerm_managed_api" "test" {
  name     = "servicebus"
  location = var.location
  depends_on = [azapi_resource.workflows, azapi_resource.namespaces]
}
resource "azapi_resource" "connection" {
  type      = "Microsoft.Web/connections@2016-06-01"
  parent_id = azapi_resource.resourceGroup.id
  name      = var.resource_name
  location  = var.location
  body = {
    properties = {
      api = {
        id = data.azurerm_managed_api.test.id
      }
      displayName = "Service Bus"
    }
  }
  schema_validation_enabled = false
  response_export_values    = ["*"]
}