Microsoft.NetApp netAppAccounts/capacityPools/volumes

Bicep resource definition

The netAppAccounts/capacityPools/volumes 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.NetApp/netAppAccounts/capacityPools/volumes resource, add the following Bicep to your template.

resource symbolicname 'Microsoft.NetApp/netAppAccounts/capacityPools/volumes@2024-07-01' = {
  parent: resourceSymbolicName
  location: 'string'
  name: 'string'
  properties: {
    avsDataStore: 'string'
    backupId: 'string'
    capacityPoolResourceId: 'string'
    coolAccess: bool
    coolAccessRetrievalPolicy: 'string'
    coolnessPeriod: int
    creationToken: 'string'
    dataProtection: {
      backup: {
        backupPolicyId: 'string'
        backupVaultId: 'string'
        policyEnforced: bool
      }
      replication: {
        endpointType: 'string'
        remotePath: {
          externalHostName: 'string'
          serverName: 'string'
          volumeName: 'string'
        }
        remoteVolumeRegion: 'string'
        remoteVolumeResourceId: 'string'
        replicationSchedule: 'string'
      }
      snapshot: {
        snapshotPolicyId: 'string'
      }
      volumeRelocation: {
        relocationRequested: bool
      }
    }
    defaultGroupQuotaInKiBs: int
    defaultUserQuotaInKiBs: int
    deleteBaseSnapshot: bool
    enableSubvolumes: 'string'
    encryptionKeySource: 'string'
    exportPolicy: {
      rules: [
        {
          allowedClients: 'string'
          chownMode: 'string'
          cifs: bool
          hasRootAccess: bool
          kerberos5iReadOnly: bool
          kerberos5iReadWrite: bool
          kerberos5pReadOnly: bool
          kerberos5pReadWrite: bool
          kerberos5ReadOnly: bool
          kerberos5ReadWrite: bool
          nfsv3: bool
          nfsv41: bool
          ruleIndex: int
          unixReadOnly: bool
          unixReadWrite: bool
        }
      ]
    }
    isDefaultQuotaEnabled: bool
    isLargeVolume: bool
    isRestoring: bool
    kerberosEnabled: bool
    keyVaultPrivateEndpointResourceId: 'string'
    ldapEnabled: bool
    networkFeatures: 'string'
    placementRules: [
      {
        key: 'string'
        value: 'string'
      }
    ]
    protocolTypes: [
      'string'
    ]
    proximityPlacementGroup: 'string'
    securityStyle: 'string'
    serviceLevel: 'string'
    smbAccessBasedEnumeration: 'string'
    smbContinuouslyAvailable: bool
    smbEncryption: bool
    smbNonBrowsable: 'string'
    snapshotDirectoryVisible: bool
    snapshotId: 'string'
    subnetId: 'string'
    throughputMibps: int
    unixPermissions: 'string'
    usageThreshold: int
    volumeSpecName: 'string'
    volumeType: 'string'
  }
  tags: {
    {customized property}: 'string'
  }
  zones: [
    'string'
  ]
}

Property values

ExportPolicyRule

Name Description Value
allowedClients Client ingress specification as comma separated string with IPv4 CIDRs, IPv4 host addresses and host names string
chownMode This parameter specifies who is authorized to change the ownership of a file. restricted - Only root user can change the ownership of the file. unrestricted - Non-root users can change ownership of files that they own. 'Restricted'
'Unrestricted'
cifs Allows CIFS protocol bool
hasRootAccess Has root access to volume bool
kerberos5iReadOnly Kerberos5i Read only access. To be use with swagger version 2020-05-01 or later bool
kerberos5iReadWrite Kerberos5i Read and write access. To be use with swagger version 2020-05-01 or later bool
kerberos5pReadOnly Kerberos5p Read only access. To be use with swagger version 2020-05-01 or later bool
kerberos5pReadWrite Kerberos5p Read and write access. To be use with swagger version 2020-05-01 or later bool
kerberos5ReadOnly Kerberos5 Read only access. To be use with swagger version 2020-05-01 or later bool
kerberos5ReadWrite Kerberos5 Read and write access. To be use with swagger version 2020-05-01 or later bool
nfsv3 Allows NFSv3 protocol. Enable only for NFSv3 type volumes bool
nfsv41 Allows NFSv4.1 protocol. Enable only for NFSv4.1 type volumes bool
ruleIndex Order index int
unixReadOnly Read only access bool
unixReadWrite Read and write access bool

Microsoft.NetApp/netAppAccounts/capacityPools/volumes

Name Description Value
location The geo-location where the resource lives string (required)
name The resource name string

Constraints:
Min length = 1
Max length = 1
Pattern = ^[a-zA-Z][a-zA-Z0-9\-_]{0,63}$ (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: netAppAccounts/capacityPools
properties Volume properties VolumeProperties (required)
tags Resource tags Dictionary of tag names and values. See Tags in templates
zones Availability Zone string

Constraints:
Min length = 1
Max length = 1[]

PlacementKeyValuePairs

Name Description Value
key Key for an application specific parameter for the placement of volumes in the volume group string (required)
value Value for an application specific parameter for the placement of volumes in the volume group string (required)

RemotePath

Name Description Value
externalHostName The Path to a ONTAP Host string (required)
serverName The name of a server on the ONTAP Host string (required)
volumeName The name of a volume on the server string (required)

ReplicationObject

Name Description Value
endpointType Indicates whether the local volume is the source or destination for the Volume Replication 'dst'
'src'
remotePath The full path to a volume that is to be migrated into ANF. Required for Migration volumes RemotePath
remoteVolumeRegion The remote region for the other end of the Volume Replication. string
remoteVolumeResourceId The resource ID of the remote volume. Required for cross region and cross zone replication string
replicationSchedule Schedule 'daily'
'hourly'
'_10minutely'

TrackedResourceTags

Name Description Value

VolumeBackupProperties

Name Description Value
backupPolicyId Backup Policy Resource ID string
backupVaultId Backup Vault Resource ID string
policyEnforced Policy Enforced bool

VolumeProperties

Name Description Value
avsDataStore Specifies whether the volume is enabled for Azure VMware Solution (AVS) datastore purpose 'Disabled'
'Enabled'
backupId Resource identifier used to identify the Backup. string
capacityPoolResourceId Pool Resource Id used in case of creating a volume through volume group string
coolAccess Specifies whether Cool Access(tiering) is enabled for the volume. bool
coolAccessRetrievalPolicy coolAccessRetrievalPolicy determines the data retrieval behavior from the cool tier to standard storage based on the read pattern for cool access enabled volumes. The possible values for this field are:
Default - Data will be pulled from cool tier to standard storage on random reads. This policy is the default.
OnRead - All client-driven data read is pulled from cool tier to standard storage on both sequential and random reads.
Never - No client-driven data is pulled from cool tier to standard storage.
'Default'
'Never'
'OnRead'
coolnessPeriod Specifies the number of days after which data that is not accessed by clients will be tiered. int

Constraints:
Min value = 2
Max value = 183
creationToken A unique file path for the volume. Used when creating mount targets string

Constraints:
Min length = 1
Max length = 1
Pattern = ^[a-zA-Z][a-zA-Z0-9\-]{0,79}$ (required)
dataProtection DataProtection type volumes include an object containing details of the replication VolumePropertiesDataProtection
defaultGroupQuotaInKiBs Default group quota for volume in KiBs. If isDefaultQuotaEnabled is set, the minimum value of 4 KiBs applies. int
defaultUserQuotaInKiBs Default user quota for volume in KiBs. If isDefaultQuotaEnabled is set, the minimum value of 4 KiBs applies . int
deleteBaseSnapshot If enabled (true) the snapshot the volume was created from will be automatically deleted after the volume create operation has finished. Defaults to false bool
enableSubvolumes Flag indicating whether subvolume operations are enabled on the volume 'Disabled'
'Enabled'
encryptionKeySource Source of key used to encrypt data in volume. Applicable if NetApp account has encryption.keySource = 'Microsoft.KeyVault'. Possible values (case-insensitive) are: 'Microsoft.NetApp, Microsoft.KeyVault' 'Microsoft.KeyVault'
'Microsoft.NetApp'
exportPolicy Set of export policy rules VolumePropertiesExportPolicy
isDefaultQuotaEnabled Specifies if default quota is enabled for the volume. bool
isLargeVolume Specifies whether volume is a Large Volume or Regular Volume. bool
isRestoring Restoring bool
kerberosEnabled Describe if a volume is KerberosEnabled. To be use with swagger version 2020-05-01 or later bool
keyVaultPrivateEndpointResourceId The resource ID of private endpoint for KeyVault. It must reside in the same VNET as the volume. Only applicable if encryptionKeySource = 'Microsoft.KeyVault'. string
ldapEnabled Specifies whether LDAP is enabled or not for a given NFS volume. bool
networkFeatures The original value of the network features type available to the volume at the time it was created. 'Basic'
'Basic_Standard'
'Standard'
'Standard_Basic'
placementRules Application specific placement rules for the particular volume PlacementKeyValuePairs[]
protocolTypes Set of protocol types, default NFSv3, CIFS for SMB protocol string[]
proximityPlacementGroup Proximity placement group associated with the volume string
securityStyle The security style of volume, default unix, defaults to ntfs for dual protocol or CIFS protocol 'ntfs'
'unix'
serviceLevel The service level of the file system 'Premium'
'Standard'
'StandardZRS'
'Ultra'
smbAccessBasedEnumeration Enables access-based enumeration share property for SMB Shares. Only applicable for SMB/DualProtocol volume 'Disabled'
'Enabled'
smbContinuouslyAvailable Enables continuously available share property for smb volume. Only applicable for SMB volume bool
smbEncryption Enables encryption for in-flight smb3 data. Only applicable for SMB/DualProtocol volume. To be used with swagger version 2020-08-01 or later bool
smbNonBrowsable Enables non-browsable property for SMB Shares. Only applicable for SMB/DualProtocol volume 'Disabled'
'Enabled'
snapshotDirectoryVisible If enabled (true) the volume will contain a read-only snapshot directory which provides access to each of the volume's snapshots (defaults to true). bool
snapshotId Resource identifier used to identify the Snapshot. string
subnetId The Azure Resource URI for a delegated subnet. Must have the delegation Microsoft.NetApp/volumes string (required)
throughputMibps Maximum throughput in MiB/s that can be achieved by this volume and this will be accepted as input only for manual qosType volume int
unixPermissions UNIX permissions for NFS volume accepted in octal 4 digit format. First digit selects the set user ID(4), set group ID (2) and sticky (1) attributes. Second digit selects permission for the owner of the file: read (4), write (2) and execute (1). Third selects permissions for other users in the same group. the fourth for other users not in the group. 0755 - gives read/write/execute permissions to owner and read/execute to group and other users. string

Constraints:
Min length = 4
Max length = 4
usageThreshold Maximum storage quota allowed for a file system in bytes. This is a soft quota used for alerting only. For regular volumes, valid values are in the range 50GiB to 100TiB. For large volumes, valid values are in the range 100TiB to 500TiB, and on an exceptional basis, from to 2400GiB to 2400TiB. Values expressed in bytes as multiples of 1 GiB. int

Constraints:
Min value = 53687091200
Max value = 2638827906662400 (required)
volumeSpecName Volume spec name is the application specific designation or identifier for the particular volume in a volume group for e.g. data, log string
volumeType What type of volume is this. For destination volumes in Cross Region Replication, set type to DataProtection string

VolumePropertiesDataProtection

Name Description Value
backup Backup Properties VolumeBackupProperties
replication Replication properties ReplicationObject
snapshot Snapshot properties. VolumeSnapshotProperties
volumeRelocation VolumeRelocation properties VolumeRelocationProperties

VolumePropertiesExportPolicy

Name Description Value
rules Export policy rule ExportPolicyRule[]

VolumeRelocationProperties

Name Description Value
relocationRequested Has relocation been requested for this volume bool

VolumeSnapshotProperties

Name Description Value
snapshotPolicyId Snapshot Policy ResourceId string

ARM template resource definition

The netAppAccounts/capacityPools/volumes 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.NetApp/netAppAccounts/capacityPools/volumes resource, add the following JSON to your template.

{
  "type": "Microsoft.NetApp/netAppAccounts/capacityPools/volumes",
  "apiVersion": "2024-07-01",
  "name": "string",
  "location": "string",
  "properties": {
    "avsDataStore": "string",
    "backupId": "string",
    "capacityPoolResourceId": "string",
    "coolAccess": "bool",
    "coolAccessRetrievalPolicy": "string",
    "coolnessPeriod": "int",
    "creationToken": "string",
    "dataProtection": {
      "backup": {
        "backupPolicyId": "string",
        "backupVaultId": "string",
        "policyEnforced": "bool"
      },
      "replication": {
        "endpointType": "string",
        "remotePath": {
          "externalHostName": "string",
          "serverName": "string",
          "volumeName": "string"
        },
        "remoteVolumeRegion": "string",
        "remoteVolumeResourceId": "string",
        "replicationSchedule": "string"
      },
      "snapshot": {
        "snapshotPolicyId": "string"
      },
      "volumeRelocation": {
        "relocationRequested": "bool"
      }
    },
    "defaultGroupQuotaInKiBs": "int",
    "defaultUserQuotaInKiBs": "int",
    "deleteBaseSnapshot": "bool",
    "enableSubvolumes": "string",
    "encryptionKeySource": "string",
    "exportPolicy": {
      "rules": [
        {
          "allowedClients": "string",
          "chownMode": "string",
          "cifs": "bool",
          "hasRootAccess": "bool",
          "kerberos5iReadOnly": "bool",
          "kerberos5iReadWrite": "bool",
          "kerberos5pReadOnly": "bool",
          "kerberos5pReadWrite": "bool",
          "kerberos5ReadOnly": "bool",
          "kerberos5ReadWrite": "bool",
          "nfsv3": "bool",
          "nfsv41": "bool",
          "ruleIndex": "int",
          "unixReadOnly": "bool",
          "unixReadWrite": "bool"
        }
      ]
    },
    "isDefaultQuotaEnabled": "bool",
    "isLargeVolume": "bool",
    "isRestoring": "bool",
    "kerberosEnabled": "bool",
    "keyVaultPrivateEndpointResourceId": "string",
    "ldapEnabled": "bool",
    "networkFeatures": "string",
    "placementRules": [
      {
        "key": "string",
        "value": "string"
      }
    ],
    "protocolTypes": [ "string" ],
    "proximityPlacementGroup": "string",
    "securityStyle": "string",
    "serviceLevel": "string",
    "smbAccessBasedEnumeration": "string",
    "smbContinuouslyAvailable": "bool",
    "smbEncryption": "bool",
    "smbNonBrowsable": "string",
    "snapshotDirectoryVisible": "bool",
    "snapshotId": "string",
    "subnetId": "string",
    "throughputMibps": "int",
    "unixPermissions": "string",
    "usageThreshold": "int",
    "volumeSpecName": "string",
    "volumeType": "string"
  },
  "tags": {
    "{customized property}": "string"
  },
  "zones": [ "string" ]
}

Property values

ExportPolicyRule

Name Description Value
allowedClients Client ingress specification as comma separated string with IPv4 CIDRs, IPv4 host addresses and host names string
chownMode This parameter specifies who is authorized to change the ownership of a file. restricted - Only root user can change the ownership of the file. unrestricted - Non-root users can change ownership of files that they own. 'Restricted'
'Unrestricted'
cifs Allows CIFS protocol bool
hasRootAccess Has root access to volume bool
kerberos5iReadOnly Kerberos5i Read only access. To be use with swagger version 2020-05-01 or later bool
kerberos5iReadWrite Kerberos5i Read and write access. To be use with swagger version 2020-05-01 or later bool
kerberos5pReadOnly Kerberos5p Read only access. To be use with swagger version 2020-05-01 or later bool
kerberos5pReadWrite Kerberos5p Read and write access. To be use with swagger version 2020-05-01 or later bool
kerberos5ReadOnly Kerberos5 Read only access. To be use with swagger version 2020-05-01 or later bool
kerberos5ReadWrite Kerberos5 Read and write access. To be use with swagger version 2020-05-01 or later bool
nfsv3 Allows NFSv3 protocol. Enable only for NFSv3 type volumes bool
nfsv41 Allows NFSv4.1 protocol. Enable only for NFSv4.1 type volumes bool
ruleIndex Order index int
unixReadOnly Read only access bool
unixReadWrite Read and write access bool

Microsoft.NetApp/netAppAccounts/capacityPools/volumes

Name Description Value
apiVersion The api version '2024-07-01'
location The geo-location where the resource lives string (required)
name The resource name string

Constraints:
Min length = 1
Max length = 1
Pattern = ^[a-zA-Z][a-zA-Z0-9\-_]{0,63}$ (required)
properties Volume properties VolumeProperties (required)
tags Resource tags Dictionary of tag names and values. See Tags in templates
type The resource type 'Microsoft.NetApp/netAppAccounts/capacityPools/volumes'
zones Availability Zone string

Constraints:
Min length = 1
Max length = 1[]

PlacementKeyValuePairs

Name Description Value
key Key for an application specific parameter for the placement of volumes in the volume group string (required)
value Value for an application specific parameter for the placement of volumes in the volume group string (required)

RemotePath

Name Description Value
externalHostName The Path to a ONTAP Host string (required)
serverName The name of a server on the ONTAP Host string (required)
volumeName The name of a volume on the server string (required)

ReplicationObject

Name Description Value
endpointType Indicates whether the local volume is the source or destination for the Volume Replication 'dst'
'src'
remotePath The full path to a volume that is to be migrated into ANF. Required for Migration volumes RemotePath
remoteVolumeRegion The remote region for the other end of the Volume Replication. string
remoteVolumeResourceId The resource ID of the remote volume. Required for cross region and cross zone replication string
replicationSchedule Schedule 'daily'
'hourly'
'_10minutely'

TrackedResourceTags

Name Description Value

VolumeBackupProperties

Name Description Value
backupPolicyId Backup Policy Resource ID string
backupVaultId Backup Vault Resource ID string
policyEnforced Policy Enforced bool

VolumeProperties

Name Description Value
avsDataStore Specifies whether the volume is enabled for Azure VMware Solution (AVS) datastore purpose 'Disabled'
'Enabled'
backupId Resource identifier used to identify the Backup. string
capacityPoolResourceId Pool Resource Id used in case of creating a volume through volume group string
coolAccess Specifies whether Cool Access(tiering) is enabled for the volume. bool
coolAccessRetrievalPolicy coolAccessRetrievalPolicy determines the data retrieval behavior from the cool tier to standard storage based on the read pattern for cool access enabled volumes. The possible values for this field are:
Default - Data will be pulled from cool tier to standard storage on random reads. This policy is the default.
OnRead - All client-driven data read is pulled from cool tier to standard storage on both sequential and random reads.
Never - No client-driven data is pulled from cool tier to standard storage.
'Default'
'Never'
'OnRead'
coolnessPeriod Specifies the number of days after which data that is not accessed by clients will be tiered. int

Constraints:
Min value = 2
Max value = 183
creationToken A unique file path for the volume. Used when creating mount targets string

Constraints:
Min length = 1
Max length = 1
Pattern = ^[a-zA-Z][a-zA-Z0-9\-]{0,79}$ (required)
dataProtection DataProtection type volumes include an object containing details of the replication VolumePropertiesDataProtection
defaultGroupQuotaInKiBs Default group quota for volume in KiBs. If isDefaultQuotaEnabled is set, the minimum value of 4 KiBs applies. int
defaultUserQuotaInKiBs Default user quota for volume in KiBs. If isDefaultQuotaEnabled is set, the minimum value of 4 KiBs applies . int
deleteBaseSnapshot If enabled (true) the snapshot the volume was created from will be automatically deleted after the volume create operation has finished. Defaults to false bool
enableSubvolumes Flag indicating whether subvolume operations are enabled on the volume 'Disabled'
'Enabled'
encryptionKeySource Source of key used to encrypt data in volume. Applicable if NetApp account has encryption.keySource = 'Microsoft.KeyVault'. Possible values (case-insensitive) are: 'Microsoft.NetApp, Microsoft.KeyVault' 'Microsoft.KeyVault'
'Microsoft.NetApp'
exportPolicy Set of export policy rules VolumePropertiesExportPolicy
isDefaultQuotaEnabled Specifies if default quota is enabled for the volume. bool
isLargeVolume Specifies whether volume is a Large Volume or Regular Volume. bool
isRestoring Restoring bool
kerberosEnabled Describe if a volume is KerberosEnabled. To be use with swagger version 2020-05-01 or later bool
keyVaultPrivateEndpointResourceId The resource ID of private endpoint for KeyVault. It must reside in the same VNET as the volume. Only applicable if encryptionKeySource = 'Microsoft.KeyVault'. string
ldapEnabled Specifies whether LDAP is enabled or not for a given NFS volume. bool
networkFeatures The original value of the network features type available to the volume at the time it was created. 'Basic'
'Basic_Standard'
'Standard'
'Standard_Basic'
placementRules Application specific placement rules for the particular volume PlacementKeyValuePairs[]
protocolTypes Set of protocol types, default NFSv3, CIFS for SMB protocol string[]
proximityPlacementGroup Proximity placement group associated with the volume string
securityStyle The security style of volume, default unix, defaults to ntfs for dual protocol or CIFS protocol 'ntfs'
'unix'
serviceLevel The service level of the file system 'Premium'
'Standard'
'StandardZRS'
'Ultra'
smbAccessBasedEnumeration Enables access-based enumeration share property for SMB Shares. Only applicable for SMB/DualProtocol volume 'Disabled'
'Enabled'
smbContinuouslyAvailable Enables continuously available share property for smb volume. Only applicable for SMB volume bool
smbEncryption Enables encryption for in-flight smb3 data. Only applicable for SMB/DualProtocol volume. To be used with swagger version 2020-08-01 or later bool
smbNonBrowsable Enables non-browsable property for SMB Shares. Only applicable for SMB/DualProtocol volume 'Disabled'
'Enabled'
snapshotDirectoryVisible If enabled (true) the volume will contain a read-only snapshot directory which provides access to each of the volume's snapshots (defaults to true). bool
snapshotId Resource identifier used to identify the Snapshot. string
subnetId The Azure Resource URI for a delegated subnet. Must have the delegation Microsoft.NetApp/volumes string (required)
throughputMibps Maximum throughput in MiB/s that can be achieved by this volume and this will be accepted as input only for manual qosType volume int
unixPermissions UNIX permissions for NFS volume accepted in octal 4 digit format. First digit selects the set user ID(4), set group ID (2) and sticky (1) attributes. Second digit selects permission for the owner of the file: read (4), write (2) and execute (1). Third selects permissions for other users in the same group. the fourth for other users not in the group. 0755 - gives read/write/execute permissions to owner and read/execute to group and other users. string

Constraints:
Min length = 4
Max length = 4
usageThreshold Maximum storage quota allowed for a file system in bytes. This is a soft quota used for alerting only. For regular volumes, valid values are in the range 50GiB to 100TiB. For large volumes, valid values are in the range 100TiB to 500TiB, and on an exceptional basis, from to 2400GiB to 2400TiB. Values expressed in bytes as multiples of 1 GiB. int

Constraints:
Min value = 53687091200
Max value = 2638827906662400 (required)
volumeSpecName Volume spec name is the application specific designation or identifier for the particular volume in a volume group for e.g. data, log string
volumeType What type of volume is this. For destination volumes in Cross Region Replication, set type to DataProtection string

VolumePropertiesDataProtection

Name Description Value
backup Backup Properties VolumeBackupProperties
replication Replication properties ReplicationObject
snapshot Snapshot properties. VolumeSnapshotProperties
volumeRelocation VolumeRelocation properties VolumeRelocationProperties

VolumePropertiesExportPolicy

Name Description Value
rules Export policy rule ExportPolicyRule[]

VolumeRelocationProperties

Name Description Value
relocationRequested Has relocation been requested for this volume bool

VolumeSnapshotProperties

Name Description Value
snapshotPolicyId Snapshot Policy ResourceId string

Quickstart templates

The following quickstart templates deploy this resource type.

Template Description
Create new ANF resource with NFSV3/NFSv4.1 volume

Deploy to Azure
This template allows you to create a new Azure NetApp Files resource with a single Capacity pool and single volume configured with NFSV3 or NFSv4.1 protocol. They are all deployed together with Azure Virtual Network and Delegated subnet that are required for any volume to be created
Create new ANF resource with SMB volume

Deploy to Azure
This template allows you to create a new Azure NetApp Files resource with a single Capacity pool and single volume configured with SMB protocol.

Terraform (AzAPI provider) resource definition

The netAppAccounts/capacityPools/volumes resource type can be deployed with operations that target:

  • Resource groups

For a list of changed properties in each API version, see change log.

Resource format

To create a Microsoft.NetApp/netAppAccounts/capacityPools/volumes resource, add the following Terraform to your template.

resource "azapi_resource" "symbolicname" {
  type = "Microsoft.NetApp/netAppAccounts/capacityPools/volumes@2024-07-01"
  name = "string"
  location = "string"
  tags = {
    {customized property} = "string"
  }
  zones = [
    "string"
  ]
  body = jsonencode({
    properties = {
      avsDataStore = "string"
      backupId = "string"
      capacityPoolResourceId = "string"
      coolAccess = bool
      coolAccessRetrievalPolicy = "string"
      coolnessPeriod = int
      creationToken = "string"
      dataProtection = {
        backup = {
          backupPolicyId = "string"
          backupVaultId = "string"
          policyEnforced = bool
        }
        replication = {
          endpointType = "string"
          remotePath = {
            externalHostName = "string"
            serverName = "string"
            volumeName = "string"
          }
          remoteVolumeRegion = "string"
          remoteVolumeResourceId = "string"
          replicationSchedule = "string"
        }
        snapshot = {
          snapshotPolicyId = "string"
        }
        volumeRelocation = {
          relocationRequested = bool
        }
      }
      defaultGroupQuotaInKiBs = int
      defaultUserQuotaInKiBs = int
      deleteBaseSnapshot = bool
      enableSubvolumes = "string"
      encryptionKeySource = "string"
      exportPolicy = {
        rules = [
          {
            allowedClients = "string"
            chownMode = "string"
            cifs = bool
            hasRootAccess = bool
            kerberos5iReadOnly = bool
            kerberos5iReadWrite = bool
            kerberos5pReadOnly = bool
            kerberos5pReadWrite = bool
            kerberos5ReadOnly = bool
            kerberos5ReadWrite = bool
            nfsv3 = bool
            nfsv41 = bool
            ruleIndex = int
            unixReadOnly = bool
            unixReadWrite = bool
          }
        ]
      }
      isDefaultQuotaEnabled = bool
      isLargeVolume = bool
      isRestoring = bool
      kerberosEnabled = bool
      keyVaultPrivateEndpointResourceId = "string"
      ldapEnabled = bool
      networkFeatures = "string"
      placementRules = [
        {
          key = "string"
          value = "string"
        }
      ]
      protocolTypes = [
        "string"
      ]
      proximityPlacementGroup = "string"
      securityStyle = "string"
      serviceLevel = "string"
      smbAccessBasedEnumeration = "string"
      smbContinuouslyAvailable = bool
      smbEncryption = bool
      smbNonBrowsable = "string"
      snapshotDirectoryVisible = bool
      snapshotId = "string"
      subnetId = "string"
      throughputMibps = int
      unixPermissions = "string"
      usageThreshold = int
      volumeSpecName = "string"
      volumeType = "string"
    }
  })
}

Property values

ExportPolicyRule

Name Description Value
allowedClients Client ingress specification as comma separated string with IPv4 CIDRs, IPv4 host addresses and host names string
chownMode This parameter specifies who is authorized to change the ownership of a file. restricted - Only root user can change the ownership of the file. unrestricted - Non-root users can change ownership of files that they own. 'Restricted'
'Unrestricted'
cifs Allows CIFS protocol bool
hasRootAccess Has root access to volume bool
kerberos5iReadOnly Kerberos5i Read only access. To be use with swagger version 2020-05-01 or later bool
kerberos5iReadWrite Kerberos5i Read and write access. To be use with swagger version 2020-05-01 or later bool
kerberos5pReadOnly Kerberos5p Read only access. To be use with swagger version 2020-05-01 or later bool
kerberos5pReadWrite Kerberos5p Read and write access. To be use with swagger version 2020-05-01 or later bool
kerberos5ReadOnly Kerberos5 Read only access. To be use with swagger version 2020-05-01 or later bool
kerberos5ReadWrite Kerberos5 Read and write access. To be use with swagger version 2020-05-01 or later bool
nfsv3 Allows NFSv3 protocol. Enable only for NFSv3 type volumes bool
nfsv41 Allows NFSv4.1 protocol. Enable only for NFSv4.1 type volumes bool
ruleIndex Order index int
unixReadOnly Read only access bool
unixReadWrite Read and write access bool

Microsoft.NetApp/netAppAccounts/capacityPools/volumes

Name Description Value
location The geo-location where the resource lives string (required)
name The resource name string

Constraints:
Min length = 1
Max length = 1
Pattern = ^[a-zA-Z][a-zA-Z0-9\-_]{0,63}$ (required)
parent_id The ID of the resource that is the parent for this resource. ID for resource of type: netAppAccounts/capacityPools
properties Volume properties VolumeProperties (required)
tags Resource tags Dictionary of tag names and values.
type The resource type "Microsoft.NetApp/netAppAccounts/capacityPools/volumes@2024-07-01"
zones Availability Zone string

Constraints:
Min length = 1
Max length = 1[]

PlacementKeyValuePairs

Name Description Value
key Key for an application specific parameter for the placement of volumes in the volume group string (required)
value Value for an application specific parameter for the placement of volumes in the volume group string (required)

RemotePath

Name Description Value
externalHostName The Path to a ONTAP Host string (required)
serverName The name of a server on the ONTAP Host string (required)
volumeName The name of a volume on the server string (required)

ReplicationObject

Name Description Value
endpointType Indicates whether the local volume is the source or destination for the Volume Replication 'dst'
'src'
remotePath The full path to a volume that is to be migrated into ANF. Required for Migration volumes RemotePath
remoteVolumeRegion The remote region for the other end of the Volume Replication. string
remoteVolumeResourceId The resource ID of the remote volume. Required for cross region and cross zone replication string
replicationSchedule Schedule 'daily'
'hourly'
'_10minutely'

TrackedResourceTags

Name Description Value

VolumeBackupProperties

Name Description Value
backupPolicyId Backup Policy Resource ID string
backupVaultId Backup Vault Resource ID string
policyEnforced Policy Enforced bool

VolumeProperties

Name Description Value
avsDataStore Specifies whether the volume is enabled for Azure VMware Solution (AVS) datastore purpose 'Disabled'
'Enabled'
backupId Resource identifier used to identify the Backup. string
capacityPoolResourceId Pool Resource Id used in case of creating a volume through volume group string
coolAccess Specifies whether Cool Access(tiering) is enabled for the volume. bool
coolAccessRetrievalPolicy coolAccessRetrievalPolicy determines the data retrieval behavior from the cool tier to standard storage based on the read pattern for cool access enabled volumes. The possible values for this field are:
Default - Data will be pulled from cool tier to standard storage on random reads. This policy is the default.
OnRead - All client-driven data read is pulled from cool tier to standard storage on both sequential and random reads.
Never - No client-driven data is pulled from cool tier to standard storage.
'Default'
'Never'
'OnRead'
coolnessPeriod Specifies the number of days after which data that is not accessed by clients will be tiered. int

Constraints:
Min value = 2
Max value = 183
creationToken A unique file path for the volume. Used when creating mount targets string

Constraints:
Min length = 1
Max length = 1
Pattern = ^[a-zA-Z][a-zA-Z0-9\-]{0,79}$ (required)
dataProtection DataProtection type volumes include an object containing details of the replication VolumePropertiesDataProtection
defaultGroupQuotaInKiBs Default group quota for volume in KiBs. If isDefaultQuotaEnabled is set, the minimum value of 4 KiBs applies. int
defaultUserQuotaInKiBs Default user quota for volume in KiBs. If isDefaultQuotaEnabled is set, the minimum value of 4 KiBs applies . int
deleteBaseSnapshot If enabled (true) the snapshot the volume was created from will be automatically deleted after the volume create operation has finished. Defaults to false bool
enableSubvolumes Flag indicating whether subvolume operations are enabled on the volume 'Disabled'
'Enabled'
encryptionKeySource Source of key used to encrypt data in volume. Applicable if NetApp account has encryption.keySource = 'Microsoft.KeyVault'. Possible values (case-insensitive) are: 'Microsoft.NetApp, Microsoft.KeyVault' 'Microsoft.KeyVault'
'Microsoft.NetApp'
exportPolicy Set of export policy rules VolumePropertiesExportPolicy
isDefaultQuotaEnabled Specifies if default quota is enabled for the volume. bool
isLargeVolume Specifies whether volume is a Large Volume or Regular Volume. bool
isRestoring Restoring bool
kerberosEnabled Describe if a volume is KerberosEnabled. To be use with swagger version 2020-05-01 or later bool
keyVaultPrivateEndpointResourceId The resource ID of private endpoint for KeyVault. It must reside in the same VNET as the volume. Only applicable if encryptionKeySource = 'Microsoft.KeyVault'. string
ldapEnabled Specifies whether LDAP is enabled or not for a given NFS volume. bool
networkFeatures The original value of the network features type available to the volume at the time it was created. 'Basic'
'Basic_Standard'
'Standard'
'Standard_Basic'
placementRules Application specific placement rules for the particular volume PlacementKeyValuePairs[]
protocolTypes Set of protocol types, default NFSv3, CIFS for SMB protocol string[]
proximityPlacementGroup Proximity placement group associated with the volume string
securityStyle The security style of volume, default unix, defaults to ntfs for dual protocol or CIFS protocol 'ntfs'
'unix'
serviceLevel The service level of the file system 'Premium'
'Standard'
'StandardZRS'
'Ultra'
smbAccessBasedEnumeration Enables access-based enumeration share property for SMB Shares. Only applicable for SMB/DualProtocol volume 'Disabled'
'Enabled'
smbContinuouslyAvailable Enables continuously available share property for smb volume. Only applicable for SMB volume bool
smbEncryption Enables encryption for in-flight smb3 data. Only applicable for SMB/DualProtocol volume. To be used with swagger version 2020-08-01 or later bool
smbNonBrowsable Enables non-browsable property for SMB Shares. Only applicable for SMB/DualProtocol volume 'Disabled'
'Enabled'
snapshotDirectoryVisible If enabled (true) the volume will contain a read-only snapshot directory which provides access to each of the volume's snapshots (defaults to true). bool
snapshotId Resource identifier used to identify the Snapshot. string
subnetId The Azure Resource URI for a delegated subnet. Must have the delegation Microsoft.NetApp/volumes string (required)
throughputMibps Maximum throughput in MiB/s that can be achieved by this volume and this will be accepted as input only for manual qosType volume int
unixPermissions UNIX permissions for NFS volume accepted in octal 4 digit format. First digit selects the set user ID(4), set group ID (2) and sticky (1) attributes. Second digit selects permission for the owner of the file: read (4), write (2) and execute (1). Third selects permissions for other users in the same group. the fourth for other users not in the group. 0755 - gives read/write/execute permissions to owner and read/execute to group and other users. string

Constraints:
Min length = 4
Max length = 4
usageThreshold Maximum storage quota allowed for a file system in bytes. This is a soft quota used for alerting only. For regular volumes, valid values are in the range 50GiB to 100TiB. For large volumes, valid values are in the range 100TiB to 500TiB, and on an exceptional basis, from to 2400GiB to 2400TiB. Values expressed in bytes as multiples of 1 GiB. int

Constraints:
Min value = 53687091200
Max value = 2638827906662400 (required)
volumeSpecName Volume spec name is the application specific designation or identifier for the particular volume in a volume group for e.g. data, log string
volumeType What type of volume is this. For destination volumes in Cross Region Replication, set type to DataProtection string

VolumePropertiesDataProtection

Name Description Value
backup Backup Properties VolumeBackupProperties
replication Replication properties ReplicationObject
snapshot Snapshot properties. VolumeSnapshotProperties
volumeRelocation VolumeRelocation properties VolumeRelocationProperties

VolumePropertiesExportPolicy

Name Description Value
rules Export policy rule ExportPolicyRule[]

VolumeRelocationProperties

Name Description Value
relocationRequested Has relocation been requested for this volume bool

VolumeSnapshotProperties

Name Description Value
snapshotPolicyId Snapshot Policy ResourceId string