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@2022-09-01-preview' = {
  parent: resourceSymbolicName
  name: 'string'
  properties: {
    apiRevision: 'string'
    apiRevisionDescription: 'string'
    apiType: 'string'
    apiVersion: 'string'
    apiVersionDescription: 'string'
    apiVersionSet: {
      description: 'string'
      id: 'string'
      name: 'string'
      versionHeaderName: 'string'
      versioningScheme: 'string'
      versionQueryName: 'string'
    }
    apiVersionSetId: 'string'
    authenticationSettings: {
      oAuth2: {
        authorizationServerId: 'string'
        scope: 'string'
      }
      oAuth2AuthenticationSettings: [
        {
          authorizationServerId: 'string'
          scope: 'string'
        }
      ]
      openid: {
        bearerTokenSendingMethods: [
          'string'
        ]
        openidProviderId: 'string'
      }
      openidAuthenticationSettings: [
        {
          bearerTokenSendingMethods: [
            'string'
          ]
          openidProviderId: 'string'
        }
      ]
    }
    contact: {
      email: 'string'
      name: 'string'
      url: 'string'
    }
    description: 'string'
    displayName: 'string'
    format: 'string'
    isCurrent: bool
    license: {
      name: 'string'
      url: 'string'
    }
    path: 'string'
    protocols: [
      'string'
    ]
    serviceUrl: 'string'
    sourceApiId: 'string'
    subscriptionKeyParameterNames: {
      header: 'string'
      query: 'string'
    }
    subscriptionRequired: bool
    termsOfServiceUrl: 'string'
    translateRequiredQueryParameters: 'string'
    type: 'string'
    value: 'string'
    wsdlSelector: {
      wsdlEndpointName: 'string'
      wsdlServiceName: 'string'
    }
  }
}
Property Values
Microsoft.ApiManagement/service/apis
| Name | Description | Value | 
|---|---|---|
| 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 | 
| properties | API entity create of update properties. | ApiCreateOrUpdatePropertiesOrApiContractProperties | 
ApiContactInformation
| Name | Description | Value | 
|---|---|---|
| The email address of the contact person/organization. MUST be in the format of an email address | string | |
| name | The identifying name of the contact person/organization | string | 
| url | The URL pointing to the contact information. MUST be in the format of a URL | string | 
ApiCreateOrUpdatePropertiesOrApiContractProperties
| Name | Description | Value | 
|---|---|---|
| apiRevision | Describes the revision of the API. If no value is provided, default revision 1 is created | string Constraints: Min length = 1 Max length = 100 | 
| apiRevisionDescription | Description of the API Revision. | string Constraints: Max length = 256 | 
| apiType | Type of API to create. * httpcreates a REST API* soapcreates a SOAP pass-through API* websocketcreates websocket API* graphqlcreates GraphQL API. | 'graphql' 'http' 'soap' 'websocket' | 
| apiVersion | Indicates the version identifier of the API if the API is versioned | string Constraints: Max length = 100 | 
| apiVersionDescription | Description of the API Version. | string Constraints: Max length = 256 | 
| apiVersionSet | Version set details | ApiVersionSetContractDetails | 
| apiVersionSetId | A resource identifier for the related ApiVersionSet. | string | 
| authenticationSettings | Collection of authentication settings included into this API. | AuthenticationSettingsContract | 
| contact | Contact information for the API. | ApiContactInformation | 
| description | Description of the API. May include HTML formatting tags. | string | 
| displayName | API name. Must be 1 to 300 characters long. | string Constraints: Min length = 1 Max length = 300 | 
| format | Format of the Content in which the API is getting imported. | 'graphql-link' 'openapi' 'openapi+json' 'openapi+json-link' 'openapi-link' 'swagger-json' 'swagger-link-json' 'wadl-link-json' 'wadl-xml' 'wsdl' 'wsdl-link' | 
| isCurrent | Indicates if API revision is current api revision. | bool | 
| license | License information for the API. | ApiLicenseInformation | 
| 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' 'ws' 'wss' | 
| serviceUrl | Absolute URL of the backend service implementing this API. Cannot be more than 2000 characters long. | string Constraints: Max length = 2000 | 
| sourceApiId | API identifier of the source API. | string | 
| subscriptionKeyParameterNames | Protocols over which API is made available. | SubscriptionKeyParameterNamesContract | 
| subscriptionRequired | Specifies whether an API or Product subscription is required for accessing the API. | bool | 
| termsOfServiceUrl | A URL to the Terms of Service for the API. MUST be in the format of a URL. | string | 
| translateRequiredQueryParameters | Strategy of translating required query parameters to template ones. By default has value 'template'. Possible values: 'template', 'query' | 'query' 'template' | 
| type | Type of API. | 'graphql' 'http' 'soap' 'websocket' | 
| value | Content value when Importing an API. | string | 
| wsdlSelector | Criteria to limit import of WSDL to a subset of the document. | ApiCreateOrUpdatePropertiesWsdlSelector | 
ApiCreateOrUpdatePropertiesWsdlSelector
| Name | Description | Value | 
|---|---|---|
| wsdlEndpointName | Name of endpoint(port) to import from WSDL | string | 
| wsdlServiceName | Name of service to import from WSDL | string | 
ApiLicenseInformation
| Name | Description | Value | 
|---|---|---|
| name | The license name used for the API | string | 
| url | A URL to the license used for the API. MUST be in the format of a URL | string | 
ApiVersionSetContractDetails
| Name | Description | Value | 
|---|---|---|
| description | Description of API Version Set. | string | 
| id | Identifier for existing API Version Set. Omit this value to create a new Version Set. | string | 
| name | The display Name of the API Version Set. | string | 
| versionHeaderName | Name of HTTP header parameter that indicates the API Version if versioningScheme is set to header. | string | 
| versioningScheme | An value that determines where the API Version identifier will be located in a HTTP request. | 'Header' 'Query' 'Segment' | 
| versionQueryName | Name of query parameter that indicates the API Version if versioningScheme is set to query. | string | 
AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| oAuth2 | OAuth2 Authentication settings | OAuth2AuthenticationSettingsContract | 
| oAuth2AuthenticationSettings | Collection of OAuth2 authentication settings included into this API. | OAuth2AuthenticationSettingsContract[] | 
| openid | OpenID Connect Authentication Settings | OpenIdAuthenticationSettingsContract | 
| openidAuthenticationSettings | Collection of Open ID Connect authentication settings included into this API. | OpenIdAuthenticationSettingsContract[] | 
OAuth2AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| authorizationServerId | OAuth authorization server identifier. | string | 
| scope | operations scope. | string | 
OpenIdAuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| bearerTokenSendingMethods | How to send token to the server. | String array containing any of: 'authorizationHeader' 'query' | 
| openidProviderId | OAuth authorization server identifier. | 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": "2022-09-01-preview",
  "name": "string",
  "properties": {
    "apiRevision": "string",
    "apiRevisionDescription": "string",
    "apiType": "string",
    "apiVersion": "string",
    "apiVersionDescription": "string",
    "apiVersionSet": {
      "description": "string",
      "id": "string",
      "name": "string",
      "versionHeaderName": "string",
      "versioningScheme": "string",
      "versionQueryName": "string"
    },
    "apiVersionSetId": "string",
    "authenticationSettings": {
      "oAuth2": {
        "authorizationServerId": "string",
        "scope": "string"
      },
      "oAuth2AuthenticationSettings": [
        {
          "authorizationServerId": "string",
          "scope": "string"
        }
      ],
      "openid": {
        "bearerTokenSendingMethods": [ "string" ],
        "openidProviderId": "string"
      },
      "openidAuthenticationSettings": [
        {
          "bearerTokenSendingMethods": [ "string" ],
          "openidProviderId": "string"
        }
      ]
    },
    "contact": {
      "email": "string",
      "name": "string",
      "url": "string"
    },
    "description": "string",
    "displayName": "string",
    "format": "string",
    "isCurrent": "bool",
    "license": {
      "name": "string",
      "url": "string"
    },
    "path": "string",
    "protocols": [ "string" ],
    "serviceUrl": "string",
    "sourceApiId": "string",
    "subscriptionKeyParameterNames": {
      "header": "string",
      "query": "string"
    },
    "subscriptionRequired": "bool",
    "termsOfServiceUrl": "string",
    "translateRequiredQueryParameters": "string",
    "type": "string",
    "value": "string",
    "wsdlSelector": {
      "wsdlEndpointName": "string",
      "wsdlServiceName": "string"
    }
  }
}
Property Values
Microsoft.ApiManagement/service/apis
| Name | Description | Value | 
|---|---|---|
| apiVersion | The api version | '2022-09-01-preview' | 
| name | The resource name | string Constraints: Min length = 1 Max length = 256 Pattern = ^[^*#&+:<>?]+$(required) | 
| properties | API entity create of update properties. | ApiCreateOrUpdatePropertiesOrApiContractProperties | 
| type | The resource type | 'Microsoft.ApiManagement/service/apis' | 
ApiContactInformation
| Name | Description | Value | 
|---|---|---|
| The email address of the contact person/organization. MUST be in the format of an email address | string | |
| name | The identifying name of the contact person/organization | string | 
| url | The URL pointing to the contact information. MUST be in the format of a URL | string | 
ApiCreateOrUpdatePropertiesOrApiContractProperties
| Name | Description | Value | 
|---|---|---|
| apiRevision | Describes the revision of the API. If no value is provided, default revision 1 is created | string Constraints: Min length = 1 Max length = 100 | 
| apiRevisionDescription | Description of the API Revision. | string Constraints: Max length = 256 | 
| apiType | Type of API to create. * httpcreates a REST API* soapcreates a SOAP pass-through API* websocketcreates websocket API* graphqlcreates GraphQL API. | 'graphql' 'http' 'soap' 'websocket' | 
| apiVersion | Indicates the version identifier of the API if the API is versioned | string Constraints: Max length = 100 | 
| apiVersionDescription | Description of the API Version. | string Constraints: Max length = 256 | 
| apiVersionSet | Version set details | ApiVersionSetContractDetails | 
| apiVersionSetId | A resource identifier for the related ApiVersionSet. | string | 
| authenticationSettings | Collection of authentication settings included into this API. | AuthenticationSettingsContract | 
| contact | Contact information for the API. | ApiContactInformation | 
| description | Description of the API. May include HTML formatting tags. | string | 
| displayName | API name. Must be 1 to 300 characters long. | string Constraints: Min length = 1 Max length = 300 | 
| format | Format of the Content in which the API is getting imported. | 'graphql-link' 'openapi' 'openapi+json' 'openapi+json-link' 'openapi-link' 'swagger-json' 'swagger-link-json' 'wadl-link-json' 'wadl-xml' 'wsdl' 'wsdl-link' | 
| isCurrent | Indicates if API revision is current api revision. | bool | 
| license | License information for the API. | ApiLicenseInformation | 
| 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' 'ws' 'wss' | 
| serviceUrl | Absolute URL of the backend service implementing this API. Cannot be more than 2000 characters long. | string Constraints: Max length = 2000 | 
| sourceApiId | API identifier of the source API. | string | 
| subscriptionKeyParameterNames | Protocols over which API is made available. | SubscriptionKeyParameterNamesContract | 
| subscriptionRequired | Specifies whether an API or Product subscription is required for accessing the API. | bool | 
| termsOfServiceUrl | A URL to the Terms of Service for the API. MUST be in the format of a URL. | string | 
| translateRequiredQueryParameters | Strategy of translating required query parameters to template ones. By default has value 'template'. Possible values: 'template', 'query' | 'query' 'template' | 
| type | Type of API. | 'graphql' 'http' 'soap' 'websocket' | 
| value | Content value when Importing an API. | string | 
| wsdlSelector | Criteria to limit import of WSDL to a subset of the document. | ApiCreateOrUpdatePropertiesWsdlSelector | 
ApiCreateOrUpdatePropertiesWsdlSelector
| Name | Description | Value | 
|---|---|---|
| wsdlEndpointName | Name of endpoint(port) to import from WSDL | string | 
| wsdlServiceName | Name of service to import from WSDL | string | 
ApiLicenseInformation
| Name | Description | Value | 
|---|---|---|
| name | The license name used for the API | string | 
| url | A URL to the license used for the API. MUST be in the format of a URL | string | 
ApiVersionSetContractDetails
| Name | Description | Value | 
|---|---|---|
| description | Description of API Version Set. | string | 
| id | Identifier for existing API Version Set. Omit this value to create a new Version Set. | string | 
| name | The display Name of the API Version Set. | string | 
| versionHeaderName | Name of HTTP header parameter that indicates the API Version if versioningScheme is set to header. | string | 
| versioningScheme | An value that determines where the API Version identifier will be located in a HTTP request. | 'Header' 'Query' 'Segment' | 
| versionQueryName | Name of query parameter that indicates the API Version if versioningScheme is set to query. | string | 
AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| oAuth2 | OAuth2 Authentication settings | OAuth2AuthenticationSettingsContract | 
| oAuth2AuthenticationSettings | Collection of OAuth2 authentication settings included into this API. | OAuth2AuthenticationSettingsContract[] | 
| openid | OpenID Connect Authentication Settings | OpenIdAuthenticationSettingsContract | 
| openidAuthenticationSettings | Collection of Open ID Connect authentication settings included into this API. | OpenIdAuthenticationSettingsContract[] | 
OAuth2AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| authorizationServerId | OAuth authorization server identifier. | string | 
| scope | operations scope. | string | 
OpenIdAuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| bearerTokenSendingMethods | How to send token to the server. | String array containing any of: 'authorizationHeader' 'query' | 
| openidProviderId | OAuth authorization server identifier. | 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@2022-09-01-preview"
  name = "string"
  parent_id = "string"
  body = {
    properties = {
      apiRevision = "string"
      apiRevisionDescription = "string"
      apiType = "string"
      apiVersion = "string"
      apiVersionDescription = "string"
      apiVersionSet = {
        description = "string"
        id = "string"
        name = "string"
        versionHeaderName = "string"
        versioningScheme = "string"
        versionQueryName = "string"
      }
      apiVersionSetId = "string"
      authenticationSettings = {
        oAuth2 = {
          authorizationServerId = "string"
          scope = "string"
        }
        oAuth2AuthenticationSettings = [
          {
            authorizationServerId = "string"
            scope = "string"
          }
        ]
        openid = {
          bearerTokenSendingMethods = [
            "string"
          ]
          openidProviderId = "string"
        }
        openidAuthenticationSettings = [
          {
            bearerTokenSendingMethods = [
              "string"
            ]
            openidProviderId = "string"
          }
        ]
      }
      contact = {
        email = "string"
        name = "string"
        url = "string"
      }
      description = "string"
      displayName = "string"
      format = "string"
      isCurrent = bool
      license = {
        name = "string"
        url = "string"
      }
      path = "string"
      protocols = [
        "string"
      ]
      serviceUrl = "string"
      sourceApiId = "string"
      subscriptionKeyParameterNames = {
        header = "string"
        query = "string"
      }
      subscriptionRequired = bool
      termsOfServiceUrl = "string"
      translateRequiredQueryParameters = "string"
      type = "string"
      value = "string"
      wsdlSelector = {
        wsdlEndpointName = "string"
        wsdlServiceName = "string"
      }
    }
  }
}
Property Values
Microsoft.ApiManagement/service/apis
| Name | Description | Value | 
|---|---|---|
| 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 | 
| properties | API entity create of update properties. | ApiCreateOrUpdatePropertiesOrApiContractProperties | 
| type | The resource type | "Microsoft.ApiManagement/service/apis@2022-09-01-preview" | 
ApiContactInformation
| Name | Description | Value | 
|---|---|---|
| The email address of the contact person/organization. MUST be in the format of an email address | string | |
| name | The identifying name of the contact person/organization | string | 
| url | The URL pointing to the contact information. MUST be in the format of a URL | string | 
ApiCreateOrUpdatePropertiesOrApiContractProperties
| Name | Description | Value | 
|---|---|---|
| apiRevision | Describes the revision of the API. If no value is provided, default revision 1 is created | string Constraints: Min length = 1 Max length = 100 | 
| apiRevisionDescription | Description of the API Revision. | string Constraints: Max length = 256 | 
| apiType | Type of API to create. * httpcreates a REST API* soapcreates a SOAP pass-through API* websocketcreates websocket API* graphqlcreates GraphQL API. | 'graphql' 'http' 'soap' 'websocket' | 
| apiVersion | Indicates the version identifier of the API if the API is versioned | string Constraints: Max length = 100 | 
| apiVersionDescription | Description of the API Version. | string Constraints: Max length = 256 | 
| apiVersionSet | Version set details | ApiVersionSetContractDetails | 
| apiVersionSetId | A resource identifier for the related ApiVersionSet. | string | 
| authenticationSettings | Collection of authentication settings included into this API. | AuthenticationSettingsContract | 
| contact | Contact information for the API. | ApiContactInformation | 
| description | Description of the API. May include HTML formatting tags. | string | 
| displayName | API name. Must be 1 to 300 characters long. | string Constraints: Min length = 1 Max length = 300 | 
| format | Format of the Content in which the API is getting imported. | 'graphql-link' 'openapi' 'openapi+json' 'openapi+json-link' 'openapi-link' 'swagger-json' 'swagger-link-json' 'wadl-link-json' 'wadl-xml' 'wsdl' 'wsdl-link' | 
| isCurrent | Indicates if API revision is current api revision. | bool | 
| license | License information for the API. | ApiLicenseInformation | 
| 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' 'ws' 'wss' | 
| serviceUrl | Absolute URL of the backend service implementing this API. Cannot be more than 2000 characters long. | string Constraints: Max length = 2000 | 
| sourceApiId | API identifier of the source API. | string | 
| subscriptionKeyParameterNames | Protocols over which API is made available. | SubscriptionKeyParameterNamesContract | 
| subscriptionRequired | Specifies whether an API or Product subscription is required for accessing the API. | bool | 
| termsOfServiceUrl | A URL to the Terms of Service for the API. MUST be in the format of a URL. | string | 
| translateRequiredQueryParameters | Strategy of translating required query parameters to template ones. By default has value 'template'. Possible values: 'template', 'query' | 'query' 'template' | 
| type | Type of API. | 'graphql' 'http' 'soap' 'websocket' | 
| value | Content value when Importing an API. | string | 
| wsdlSelector | Criteria to limit import of WSDL to a subset of the document. | ApiCreateOrUpdatePropertiesWsdlSelector | 
ApiCreateOrUpdatePropertiesWsdlSelector
| Name | Description | Value | 
|---|---|---|
| wsdlEndpointName | Name of endpoint(port) to import from WSDL | string | 
| wsdlServiceName | Name of service to import from WSDL | string | 
ApiLicenseInformation
| Name | Description | Value | 
|---|---|---|
| name | The license name used for the API | string | 
| url | A URL to the license used for the API. MUST be in the format of a URL | string | 
ApiVersionSetContractDetails
| Name | Description | Value | 
|---|---|---|
| description | Description of API Version Set. | string | 
| id | Identifier for existing API Version Set. Omit this value to create a new Version Set. | string | 
| name | The display Name of the API Version Set. | string | 
| versionHeaderName | Name of HTTP header parameter that indicates the API Version if versioningScheme is set to header. | string | 
| versioningScheme | An value that determines where the API Version identifier will be located in a HTTP request. | 'Header' 'Query' 'Segment' | 
| versionQueryName | Name of query parameter that indicates the API Version if versioningScheme is set to query. | string | 
AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| oAuth2 | OAuth2 Authentication settings | OAuth2AuthenticationSettingsContract | 
| oAuth2AuthenticationSettings | Collection of OAuth2 authentication settings included into this API. | OAuth2AuthenticationSettingsContract[] | 
| openid | OpenID Connect Authentication Settings | OpenIdAuthenticationSettingsContract | 
| openidAuthenticationSettings | Collection of Open ID Connect authentication settings included into this API. | OpenIdAuthenticationSettingsContract[] | 
OAuth2AuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| authorizationServerId | OAuth authorization server identifier. | string | 
| scope | operations scope. | string | 
OpenIdAuthenticationSettingsContract
| Name | Description | Value | 
|---|---|---|
| bearerTokenSendingMethods | How to send token to the server. | String array containing any of: 'authorizationHeader' 'query' | 
| openidProviderId | OAuth authorization server identifier. | 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    = ["*"]
}