Bicep resource definition
The vaults 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.RecoveryServices/vaults resource, add the following Bicep to your template.
resource symbolicname 'Microsoft.RecoveryServices/vaults@2023-06-01' = {
  scope: resourceSymbolicName or scope
  etag: 'string'
  identity: {
    type: 'string'
    userAssignedIdentities: {
      {customized property}: {}
    }
  }
  location: 'string'
  name: 'string'
  properties: {
    encryption: {
      infrastructureEncryption: 'string'
      kekIdentity: {
        userAssignedIdentity: 'string'
        useSystemAssignedIdentity: bool
      }
      keyVaultProperties: {
        keyUri: 'string'
      }
    }
    monitoringSettings: {
      azureMonitorAlertSettings: {
        alertsForAllJobFailures: 'string'
      }
      classicAlertSettings: {
        alertsForCriticalOperations: 'string'
      }
    }
    moveDetails: {}
    publicNetworkAccess: 'string'
    redundancySettings: {}
    restoreSettings: {
      crossSubscriptionRestoreSettings: {
        crossSubscriptionRestoreState: 'string'
      }
    }
    securitySettings: {
      immutabilitySettings: {
        state: 'string'
      }
      softDeleteSettings: {
        softDeleteRetentionPeriodInDays: int
        softDeleteState: 'string'
      }
    }
    upgradeDetails: {}
  }
  sku: {
    capacity: 'string'
    family: 'string'
    name: 'string'
    size: 'string'
    tier: 'string'
  }
  tags: {
    {customized property}: 'string'
  }
}
Property Values
Microsoft.RecoveryServices/vaults
| Name | Description | Value | 
| etag | Optional ETag. | string | 
| identity | Identity for the resource. | IdentityData | 
| location | Resource location. | string (required) | 
| name | The resource name | string (required) | 
| properties | Properties of the vault. | VaultProperties | 
| 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. | 
| sku | Identifies the unique system identifier for each Azure resource. | Sku | 
| tags | Resource tags | Dictionary of tag names and values. See Tags in templates | 
AzureMonitorAlertSettings
| Name | Description | Value | 
| alertsForAllJobFailures |  | 'Disabled' 'Enabled'
 | 
ClassicAlertSettings
| Name | Description | Value | 
| alertsForCriticalOperations |  | 'Disabled' 'Enabled'
 | 
CmkKekIdentity
| Name | Description | Value | 
| userAssignedIdentity | The user assigned identity to be used to grant permissions in case the type of identity used is UserAssigned | string | 
| useSystemAssignedIdentity | Indicate that system assigned identity should be used. Mutually exclusive with 'userAssignedIdentity' field | bool | 
CmkKeyVaultProperties
| Name | Description | Value | 
| keyUri | The key uri of the Customer Managed Key | string | 
CrossSubscriptionRestoreSettings
| Name | Description | Value | 
| crossSubscriptionRestoreState |  | 'Disabled' 'Enabled'
 'PermanentlyDisabled'
 | 
IdentityData
| Name | Description | Value | 
| type | The type of managed identity used. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user-assigned identities. The type 'None' will remove any identities. | 'None' 'SystemAssigned'
 'SystemAssigned, UserAssigned'
 'UserAssigned' (required)
 | 
| userAssignedIdentities | The list of user-assigned identities associated with the resource. The user-assigned identity dictionary keys will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. | IdentityDataUserAssignedIdentities | 
IdentityDataUserAssignedIdentities
ImmutabilitySettings
| Name | Description | Value | 
| state |  | 'Disabled' 'Locked'
 'Unlocked'
 | 
MonitoringSettings
RestoreSettings
SecuritySettings
Sku
| Name | Description | Value | 
| capacity | The sku capacity | string | 
| family | The sku family | string | 
| name | Name of SKU is RS0 (Recovery Services 0th version) and the tier is standard tier. They do not have affect on backend storage redundancy or any other vault settings. To manage storage redundancy, use the backupstorageconfig | 'RS0' 'Standard' (required)
 | 
| size | The sku size | string | 
| tier | The Sku tier. | string | 
SoftDeleteSettings
| Name | Description | Value | 
| softDeleteRetentionPeriodInDays | Soft delete retention period in days | int | 
| softDeleteState |  | 'AlwaysON' 'Disabled'
 'Enabled'
 'Invalid'
 | 
UpgradeDetails
UserIdentity
VaultProperties
VaultPropertiesEncryption
| Name | Description | Value | 
| infrastructureEncryption | Enabling/Disabling the Double Encryption state | 'Disabled' 'Enabled'
 | 
| kekIdentity | The details of the identity used for CMK | CmkKekIdentity | 
| keyVaultProperties | The properties of the Key Vault which hosts CMK | CmkKeyVaultProperties | 
VaultPropertiesMoveDetails
VaultPropertiesRedundancySettings
Usage Examples
Azure Verified Modules
The following Azure Verified Modules can be used to deploy this resource type.
Azure Quickstart Samples
The following Azure Quickstart templates contain Bicep samples for deploying this resource type.
 
ARM template resource definition
The vaults 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.RecoveryServices/vaults resource, add the following JSON to your template.
{
  "type": "Microsoft.RecoveryServices/vaults",
  "apiVersion": "2023-06-01",
  "name": "string",
  "etag": "string",
  "identity": {
    "type": "string",
    "userAssignedIdentities": {
      "{customized property}": {
      }
    }
  },
  "location": "string",
  "properties": {
    "encryption": {
      "infrastructureEncryption": "string",
      "kekIdentity": {
        "userAssignedIdentity": "string",
        "useSystemAssignedIdentity": "bool"
      },
      "keyVaultProperties": {
        "keyUri": "string"
      }
    },
    "monitoringSettings": {
      "azureMonitorAlertSettings": {
        "alertsForAllJobFailures": "string"
      },
      "classicAlertSettings": {
        "alertsForCriticalOperations": "string"
      }
    },
    "moveDetails": {
    },
    "publicNetworkAccess": "string",
    "redundancySettings": {
    },
    "restoreSettings": {
      "crossSubscriptionRestoreSettings": {
        "crossSubscriptionRestoreState": "string"
      }
    },
    "securitySettings": {
      "immutabilitySettings": {
        "state": "string"
      },
      "softDeleteSettings": {
        "softDeleteRetentionPeriodInDays": "int",
        "softDeleteState": "string"
      }
    },
    "upgradeDetails": {
    }
  },
  "sku": {
    "capacity": "string",
    "family": "string",
    "name": "string",
    "size": "string",
    "tier": "string"
  },
  "tags": {
    "{customized property}": "string"
  }
}
Property Values
Microsoft.RecoveryServices/vaults
| Name | Description | Value | 
| apiVersion | The api version | '2023-06-01' | 
| etag | Optional ETag. | string | 
| identity | Identity for the resource. | IdentityData | 
| location | Resource location. | string (required) | 
| name | The resource name | string (required) | 
| properties | Properties of the vault. | VaultProperties | 
| sku | Identifies the unique system identifier for each Azure resource. | Sku | 
| tags | Resource tags | Dictionary of tag names and values. See Tags in templates | 
| type | The resource type | 'Microsoft.RecoveryServices/vaults' | 
AzureMonitorAlertSettings
| Name | Description | Value | 
| alertsForAllJobFailures |  | 'Disabled' 'Enabled'
 | 
ClassicAlertSettings
| Name | Description | Value | 
| alertsForCriticalOperations |  | 'Disabled' 'Enabled'
 | 
CmkKekIdentity
| Name | Description | Value | 
| userAssignedIdentity | The user assigned identity to be used to grant permissions in case the type of identity used is UserAssigned | string | 
| useSystemAssignedIdentity | Indicate that system assigned identity should be used. Mutually exclusive with 'userAssignedIdentity' field | bool | 
CmkKeyVaultProperties
| Name | Description | Value | 
| keyUri | The key uri of the Customer Managed Key | string | 
CrossSubscriptionRestoreSettings
| Name | Description | Value | 
| crossSubscriptionRestoreState |  | 'Disabled' 'Enabled'
 'PermanentlyDisabled'
 | 
IdentityData
| Name | Description | Value | 
| type | The type of managed identity used. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user-assigned identities. The type 'None' will remove any identities. | 'None' 'SystemAssigned'
 'SystemAssigned, UserAssigned'
 'UserAssigned' (required)
 | 
| userAssignedIdentities | The list of user-assigned identities associated with the resource. The user-assigned identity dictionary keys will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. | IdentityDataUserAssignedIdentities | 
IdentityDataUserAssignedIdentities
ImmutabilitySettings
| Name | Description | Value | 
| state |  | 'Disabled' 'Locked'
 'Unlocked'
 | 
MonitoringSettings
RestoreSettings
SecuritySettings
Sku
| Name | Description | Value | 
| capacity | The sku capacity | string | 
| family | The sku family | string | 
| name | Name of SKU is RS0 (Recovery Services 0th version) and the tier is standard tier. They do not have affect on backend storage redundancy or any other vault settings. To manage storage redundancy, use the backupstorageconfig | 'RS0' 'Standard' (required)
 | 
| size | The sku size | string | 
| tier | The Sku tier. | string | 
SoftDeleteSettings
| Name | Description | Value | 
| softDeleteRetentionPeriodInDays | Soft delete retention period in days | int | 
| softDeleteState |  | 'AlwaysON' 'Disabled'
 'Enabled'
 'Invalid'
 | 
UpgradeDetails
UserIdentity
VaultProperties
VaultPropertiesEncryption
| Name | Description | Value | 
| infrastructureEncryption | Enabling/Disabling the Double Encryption state | 'Disabled' 'Enabled'
 | 
| kekIdentity | The details of the identity used for CMK | CmkKekIdentity | 
| keyVaultProperties | The properties of the Key Vault which hosts CMK | CmkKeyVaultProperties | 
VaultPropertiesMoveDetails
VaultPropertiesRedundancySettings
Usage Examples
Azure Quickstart Templates
The following Azure Quickstart templates deploy this resource type.
| Template | Description | 
| Azure Backup for Workload in Azure Virtual Machines 
 
  | This template creates a Recovery Services Vault and a Workload specific Backup Policy. Registers VM with Backup service and Configures Protection | 
| Backup existing File Share using Recovery Services (Daily) 
 
  | This template configures protection for an existing File Share present in an existing Storage Account. It creates a new or uses an existing Recovery Services Vault and Backup Policy based on the set parameter values. | 
| Backup existing File Share using Recovery Services (hourly) 
 
  | This template configures protection with hourly frequency for an existing File Share present in an existing Storage Account. It creates a new or uses an existing Recovery Services Vault and Backup Policy based on the set parameter values. | 
| Backup Resource Manager VMs using Recovery Services vault 
 
  | This template will use existing recovery services vault and existing backup policy, and configures backup of multiple Resource Manager VMs that belong to same resource group | 
| Create a Recovery Services vault with advanced options 
 
  | This template creates a Recovery Services vault that will be used further for Backup and Site Recovery. | 
| Create AVD with FSLogix and AD DS Join 
 
  | This template allows you to create Azure Virtual Desktop resources such as host pool, application group, workspace, FSLogix storage account, file share, recovery service vault for file share backup a test session host, its extensions with Microsoft Entra ID join pr Active directory domain join. | 
| Create Azure VM Replication and Disaster Recovery 
 
  | This template allows you to create Azure Virtual machine site replication disaster recovery. | 
| Create Daily Backup Policy for RS Vault to protect IaaSVMs 
 
  | This template creates Recovery service vault and a Daily Backup Policy that can be used to protect classic and ARM based IaaS VMs. | 
| Create Recovery Services Vault and Enable Diagnostics 
 
  | This template creates a Recovery Services Vault and enables diagnostics for Azure Backup. This also deploys storage account and oms workspace. | 
| Create Recovery Services Vault with backup policies 
 
  | This template creates a Recovery Services Vault with backup policies and configure optional features such system identity, backup storage type, cross region restore and diagnostics logs and a delete lock. | 
| Create Recovery Services Vault with default options 
 
  | Simple template that creates a Recovery Services Vault. | 
| Create Weekly Backup Policy for RS Vault to protect IaaSVMs 
 
  | This template creates Recovery service vault and a Daily Backup Policy that can be used to protect classic and ARM based IaaS VMs. | 
| Deploy a Windows VM and enable backup using Azure Backup 
 
  | This template allows you to deploy a Windows VM and Recovery Services Vault configured with the DefaultPolicy for Protection. | 
| IBM Cloud Pak for Data on Azure 
 
  | This template deploys an Openshift cluster on Azure with all the required resources, infrastructure and then deploys IBM Cloud Pak for Data  along with the add-ons that user chooses. | 
| Openshift Container Platform 4.3 
 
  | Openshift Container Platform 4.3 | 
 
 
The vaults 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.RecoveryServices/vaults resource, add the following Terraform to your template.
resource "azapi_resource" "symbolicname" {
  type = "Microsoft.RecoveryServices/vaults@2023-06-01"
  name = "string"
  parent_id = "string"
  identity {
    type = "string"
    identity_ids = [
      "string"
    ]
  }
  location = "string"
  tags = {
    {customized property} = "string"
  }
  body = {
    etag = "string"
    properties = {
      encryption = {
        infrastructureEncryption = "string"
        kekIdentity = {
          userAssignedIdentity = "string"
          useSystemAssignedIdentity = bool
        }
        keyVaultProperties = {
          keyUri = "string"
        }
      }
      monitoringSettings = {
        azureMonitorAlertSettings = {
          alertsForAllJobFailures = "string"
        }
        classicAlertSettings = {
          alertsForCriticalOperations = "string"
        }
      }
      moveDetails = {
      }
      publicNetworkAccess = "string"
      redundancySettings = {
      }
      restoreSettings = {
        crossSubscriptionRestoreSettings = {
          crossSubscriptionRestoreState = "string"
        }
      }
      securitySettings = {
        immutabilitySettings = {
          state = "string"
        }
        softDeleteSettings = {
          softDeleteRetentionPeriodInDays = int
          softDeleteState = "string"
        }
      }
      upgradeDetails = {
      }
    }
    sku = {
      capacity = "string"
      family = "string"
      name = "string"
      size = "string"
      tier = "string"
    }
  }
}
Property Values
Microsoft.RecoveryServices/vaults
| Name | Description | Value | 
| etag | Optional ETag. | string | 
| identity | Identity for the resource. | IdentityData | 
| location | Resource location. | string (required) | 
| name | The resource name | string (required) | 
| parent_id | The ID of the resource to apply this extension resource to. | string (required) | 
| properties | Properties of the vault. | VaultProperties | 
| sku | Identifies the unique system identifier for each Azure resource. | Sku | 
| tags | Resource tags | Dictionary of tag names and values. | 
| type | The resource type | "Microsoft.RecoveryServices/vaults@2023-06-01" | 
AzureMonitorAlertSettings
| Name | Description | Value | 
| alertsForAllJobFailures |  | 'Disabled' 'Enabled'
 | 
ClassicAlertSettings
| Name | Description | Value | 
| alertsForCriticalOperations |  | 'Disabled' 'Enabled'
 | 
CmkKekIdentity
| Name | Description | Value | 
| userAssignedIdentity | The user assigned identity to be used to grant permissions in case the type of identity used is UserAssigned | string | 
| useSystemAssignedIdentity | Indicate that system assigned identity should be used. Mutually exclusive with 'userAssignedIdentity' field | bool | 
CmkKeyVaultProperties
| Name | Description | Value | 
| keyUri | The key uri of the Customer Managed Key | string | 
CrossSubscriptionRestoreSettings
| Name | Description | Value | 
| crossSubscriptionRestoreState |  | 'Disabled' 'Enabled'
 'PermanentlyDisabled'
 | 
IdentityData
| Name | Description | Value | 
| type | The type of managed identity used. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user-assigned identities. The type 'None' will remove any identities. | 'None' 'SystemAssigned'
 'SystemAssigned, UserAssigned'
 'UserAssigned' (required)
 | 
| userAssignedIdentities | The list of user-assigned identities associated with the resource. The user-assigned identity dictionary keys will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. | IdentityDataUserAssignedIdentities | 
IdentityDataUserAssignedIdentities
ImmutabilitySettings
| Name | Description | Value | 
| state |  | 'Disabled' 'Locked'
 'Unlocked'
 | 
MonitoringSettings
RestoreSettings
SecuritySettings
Sku
| Name | Description | Value | 
| capacity | The sku capacity | string | 
| family | The sku family | string | 
| name | Name of SKU is RS0 (Recovery Services 0th version) and the tier is standard tier. They do not have affect on backend storage redundancy or any other vault settings. To manage storage redundancy, use the backupstorageconfig | 'RS0' 'Standard' (required)
 | 
| size | The sku size | string | 
| tier | The Sku tier. | string | 
SoftDeleteSettings
| Name | Description | Value | 
| softDeleteRetentionPeriodInDays | Soft delete retention period in days | int | 
| softDeleteState |  | 'AlwaysON' 'Disabled'
 'Enabled'
 'Invalid'
 | 
UpgradeDetails
UserIdentity
VaultProperties
VaultPropertiesEncryption
| Name | Description | Value | 
| infrastructureEncryption | Enabling/Disabling the Double Encryption state | 'Disabled' 'Enabled'
 | 
| kekIdentity | The details of the identity used for CMK | CmkKekIdentity | 
| keyVaultProperties | The properties of the Key Vault which hosts CMK | CmkKeyVaultProperties | 
VaultPropertiesMoveDetails
VaultPropertiesRedundancySettings
Usage Examples
A basic example of deploying Recovery Services Vault.
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" "vault" {
  type      = "Microsoft.RecoveryServices/vaults@2022-10-01"
  parent_id = azapi_resource.resourceGroup.id
  name      = var.resource_name
  location  = var.location
  body = {
    properties = {
      publicNetworkAccess = "Enabled"
    }
    sku = {
      name = "Standard"
    }
  }
  schema_validation_enabled = false
  response_export_values    = ["*"]
}
Azure Verified Modules
The following Azure Verified Modules can be used to deploy this resource type.