Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
- Latest
- 2024-10-01-preview
- 2024-06-01-preview
- 2024-05-01
- 2023-09-01-preview
- 2023-05-01-preview
- 2023-03-01-preview
- 2022-09-01-preview
- 2022-08-01
- 2022-04-01-preview
- 2021-12-01-preview
- 2021-08-01
- 2021-04-01-preview
- 2021-01-01-preview
- 2020-12-01
- 2020-06-01-preview
- 2019-12-01
- 2019-12-01-preview
- 2019-01-01
- 2018-06-01-preview
- 2018-01-01
- 2017-03-01
- 2016-10-10
- 2016-07-07
Bicep resource definition
The service/apis resource type can be deployed with operations that target:
For a list of changed properties in each API version, see change log.
Resource format
To create a Microsoft.ApiManagement/service/apis resource, add the following Bicep to your template.
resource symbolicname 'Microsoft.ApiManagement/service/apis@2016-07-07' = {
  parent: resourceSymbolicName
  authenticationSettings: {
    oAuth2: {
      authorizationServerId: 'string'
      scope: 'string'
    }
  }
  description: 'string'
  name: 'string'
  path: 'string'
  protocols: [
    'string'
  ]
  serviceUrl: 'string'
  subscriptionKeyParameterNames: {
    header: 'string'
    query: 'string'
  }
}
Property Values
Microsoft.ApiManagement/service/apis
| Name | Description | Value | 
|---|---|---|
| authenticationSettings | Collection of authentication settings included into this API. | AuthenticationSettingsContract | 
| description | Description of the API. May include HTML formatting tags. | string | 
| name | The resource name | string Constraints: Min length = 1 Max length = 256 Pattern = ^[^*#&+:<>?]+$(required) | 
| parent | In Bicep, you can specify the parent resource for a child resource. You only need to add this property when the child resource is declared outside of the parent resource. For more information, see Child resource outside parent resource. | Symbolic name for resource of type: service | 
| path | Relative URL uniquely identifying this API and all of its resource paths within the API Management service instance. It is appended to the API endpoint base URL specified during the service instance creation to form a public URL for this API. | string Constraints: Max length = 400 (required) | 
| protocols | Describes on which protocols the operations in this API can be invoked. | String array containing any of: 'Http' 'Https' (required) | 
| serviceUrl | Absolute URL of the backend service implementing this API. | string Constraints: Min length = 1 Max length = 2000 (required) | 
| subscriptionKeyParameterNames | Protocols over which API is made available. | SubscriptionKeyParameterNamesContract | 
AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| oAuth2 | API OAuth2 Authentication settings details. | OAuth2AuthenticationSettingsContract | 
OAuth2AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| authorizationServerId | OAuth authorization server identifier. | string | 
| scope | operations scope. | string | 
SubscriptionKeyParameterNamesContract
| Name | Description | Value | 
|---|---|---|
| header | Subscription key header name. | string | 
| query | Subscription key query string parameter name. | string | 
ARM template resource definition
The service/apis resource type can be deployed with operations that target:
For a list of changed properties in each API version, see change log.
Resource format
To create a Microsoft.ApiManagement/service/apis resource, add the following JSON to your template.
{
  "type": "Microsoft.ApiManagement/service/apis",
  "apiVersion": "2016-07-07",
  "name": "string",
  "authenticationSettings": {
    "oAuth2": {
      "authorizationServerId": "string",
      "scope": "string"
    }
  },
  "description": "string",
  "path": "string",
  "protocols": [ "string" ],
  "serviceUrl": "string",
  "subscriptionKeyParameterNames": {
    "header": "string",
    "query": "string"
  }
}
Property Values
Microsoft.ApiManagement/service/apis
| Name | Description | Value | 
|---|---|---|
| apiVersion | The api version | '2016-07-07' | 
| authenticationSettings | Collection of authentication settings included into this API. | AuthenticationSettingsContract | 
| description | Description of the API. May include HTML formatting tags. | string | 
| name | The resource name | string Constraints: Min length = 1 Max length = 256 Pattern = ^[^*#&+:<>?]+$(required) | 
| path | Relative URL uniquely identifying this API and all of its resource paths within the API Management service instance. It is appended to the API endpoint base URL specified during the service instance creation to form a public URL for this API. | string Constraints: Max length = 400 (required) | 
| protocols | Describes on which protocols the operations in this API can be invoked. | String array containing any of: 'Http' 'Https' (required) | 
| serviceUrl | Absolute URL of the backend service implementing this API. | string Constraints: Min length = 1 Max length = 2000 (required) | 
| subscriptionKeyParameterNames | Protocols over which API is made available. | SubscriptionKeyParameterNamesContract | 
| type | The resource type | 'Microsoft.ApiManagement/service/apis' | 
AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| oAuth2 | API OAuth2 Authentication settings details. | OAuth2AuthenticationSettingsContract | 
OAuth2AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| authorizationServerId | OAuth authorization server identifier. | string | 
| scope | operations scope. | string | 
SubscriptionKeyParameterNamesContract
| Name | Description | Value | 
|---|---|---|
| header | Subscription key header name. | string | 
| query | Subscription key query string parameter name. | string | 
Usage Examples
Terraform (AzAPI provider) resource definition
The service/apis resource type can be deployed with operations that target:
For a list of changed properties in each API version, see change log.
Resource format
To create a Microsoft.ApiManagement/service/apis resource, add the following Terraform to your template.
resource "azapi_resource" "symbolicname" {
  type = "Microsoft.ApiManagement/service/apis@2016-07-07"
  name = "string"
  parent_id = "string"
  body = {
    authenticationSettings = {
      oAuth2 = {
        authorizationServerId = "string"
        scope = "string"
      }
    }
    description = "string"
    path = "string"
    protocols = [
      "string"
    ]
    serviceUrl = "string"
    subscriptionKeyParameterNames = {
      header = "string"
      query = "string"
    }
  }
}
Property Values
Microsoft.ApiManagement/service/apis
| Name | Description | Value | 
|---|---|---|
| authenticationSettings | Collection of authentication settings included into this API. | AuthenticationSettingsContract | 
| description | Description of the API. May include HTML formatting tags. | string | 
| name | The resource name | string Constraints: Min length = 1 Max length = 256 Pattern = ^[^*#&+:<>?]+$(required) | 
| parent_id | The ID of the resource that is the parent for this resource. | ID for resource of type: service | 
| path | Relative URL uniquely identifying this API and all of its resource paths within the API Management service instance. It is appended to the API endpoint base URL specified during the service instance creation to form a public URL for this API. | string Constraints: Max length = 400 (required) | 
| protocols | Describes on which protocols the operations in this API can be invoked. | String array containing any of: 'Http' 'Https' (required) | 
| serviceUrl | Absolute URL of the backend service implementing this API. | string Constraints: Min length = 1 Max length = 2000 (required) | 
| subscriptionKeyParameterNames | Protocols over which API is made available. | SubscriptionKeyParameterNamesContract | 
| type | The resource type | "Microsoft.ApiManagement/service/apis@2016-07-07" | 
AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| oAuth2 | API OAuth2 Authentication settings details. | OAuth2AuthenticationSettingsContract | 
OAuth2AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| authorizationServerId | OAuth authorization server identifier. | string | 
| scope | operations scope. | string | 
SubscriptionKeyParameterNamesContract
| Name | Description | Value | 
|---|---|---|
| header | Subscription key header name. | string | 
| query | Subscription key query string parameter name. | string | 
Usage Examples
Terraform Samples
A basic example of deploying API within an API Management Service.
terraform {
  required_providers {
    azapi = {
      source = "Azure/azapi"
    }
  }
}
provider "azapi" {
  skip_provider_registration = false
}
variable "resource_name" {
  type    = string
  default = "acctest0001"
}
variable "location" {
  type    = string
  default = "westeurope"
}
resource "azapi_resource" "resourceGroup" {
  type     = "Microsoft.Resources/resourceGroups@2020-06-01"
  name     = var.resource_name
  location = var.location
}
resource "azapi_resource" "service" {
  type      = "Microsoft.ApiManagement/service@2021-08-01"
  parent_id = azapi_resource.resourceGroup.id
  name      = var.resource_name
  location  = var.location
  body = {
    properties = {
      certificates = [
      ]
      customProperties = {
        "Microsoft.WindowsAzure.ApiManagement.Gateway.Security.Backend.Protocols.Ssl30" = "false"
        "Microsoft.WindowsAzure.ApiManagement.Gateway.Security.Backend.Protocols.Tls10" = "false"
        "Microsoft.WindowsAzure.ApiManagement.Gateway.Security.Backend.Protocols.Tls11" = "false"
        "Microsoft.WindowsAzure.ApiManagement.Gateway.Security.Protocols.Tls10"         = "false"
        "Microsoft.WindowsAzure.ApiManagement.Gateway.Security.Protocols.Tls11"         = "false"
      }
      disableGateway      = false
      publicNetworkAccess = "Enabled"
      publisherEmail      = "pub1@email.com"
      publisherName       = "pub1"
      virtualNetworkType  = "None"
    }
    sku = {
      capacity = 0
      name     = "Consumption"
    }
  }
  schema_validation_enabled = false
  response_export_values    = ["*"]
}
resource "azapi_resource" "api" {
  type      = "Microsoft.ApiManagement/service/apis@2021-08-01"
  parent_id = azapi_resource.service.id
  name      = "${var.resource_name};rev=1"
  body = {
    properties = {
      apiRevisionDescription = ""
      apiType                = "http"
      apiVersion             = ""
      apiVersionDescription  = ""
      authenticationSettings = {
      }
      description = ""
      displayName = "api1"
      path        = "api1"
      protocols = [
        "https",
      ]
      serviceUrl           = ""
      subscriptionRequired = true
      type                 = "http"
    }
  }
  schema_validation_enabled = false
  response_export_values    = ["*"]
}