# encoding: utf-8
# Code generated by Microsoft (R) AutoRest Code Generator.
# Changes may cause incorrect behavior and will be lost if the code is
# regenerated.
module Azure::Compute::Mgmt::V2020_12_01
module Models
#
# Describes a data disk.
#
class DataDisk
include MsRestAzure
# @return [Integer] Specifies the logical unit number of the data disk.
# This value is used to identify data disks within the VM and therefore
# must be unique for each data disk attached to a VM.
attr_accessor :lun
# @return [String] The disk name.
attr_accessor :name
# @return [VirtualHardDisk] The virtual hard disk.
attr_accessor :vhd
# @return [VirtualHardDisk] The source user image virtual hard disk. The
# virtual hard disk will be copied before being attached to the virtual
# machine. If SourceImage is provided, the destination virtual hard drive
# must not exist.
attr_accessor :image
# @return [CachingTypes] Specifies the caching requirements.
# Possible values are:
**None**
**ReadOnly**
# **ReadWrite**
Default: **None for Standard storage. ReadOnly
# for Premium storage**. Possible values include: 'None', 'ReadOnly',
# 'ReadWrite'
attr_accessor :caching
# @return [Boolean] Specifies whether writeAccelerator should be enabled
# or disabled on the disk.
attr_accessor :write_accelerator_enabled
# @return [DiskCreateOptionTypes] Specifies how the virtual machine
# should be created.
Possible values are:
**Attach**
# \u2013 This value is used when you are using a specialized disk to
# create the virtual machine.
**FromImage** \u2013 This value is
# used when you are using an image to create the virtual machine. If you
# are using a platform image, you also use the imageReference element
# described above. If you are using a marketplace image, you also use
# the plan element previously described. Possible values include:
# 'FromImage', 'Empty', 'Attach'
attr_accessor :create_option
# @return [Integer] Specifies the size of an empty data disk in
# gigabytes. This element can be used to overwrite the size of the disk
# in a virtual machine image.
This value cannot be larger than
# 1023 GB
attr_accessor :disk_size_gb
# @return [ManagedDiskParameters] The managed disk parameters.
attr_accessor :managed_disk
# @return [Boolean] Specifies whether the data disk is in process of
# detachment from the VirtualMachine/VirtualMachineScaleset
attr_accessor :to_be_detached
# @return [Integer] Specifies the Read-Write IOPS for the managed disk
# when StorageAccountType is UltraSSD_LRS. Returned only for
# VirtualMachine ScaleSet VM disks. Can be updated only via updates to
# the VirtualMachine Scale Set.
attr_accessor :disk_iopsread_write
# @return [Integer] Specifies the bandwidth in MB per second for the
# managed disk when StorageAccountType is UltraSSD_LRS. Returned only for
# VirtualMachine ScaleSet VM disks. Can be updated only via updates to
# the VirtualMachine Scale Set.
attr_accessor :disk_mbps_read_write
# @return [DiskDetachOptionTypes] Specifies the detach behavior to be
# used while detaching a disk or which is already in the process of
# detachment from the virtual machine. Supported values: **ForceDetach**.
#
detachOption: **ForceDetach** is applicable only for managed
# data disks. If a previous detachment attempt of the data disk did not
# complete due to an unexpected failure from the virtual machine and the
# disk is still not released then use force-detach as a last resort
# option to detach the disk forcibly from the VM. All writes might not
# have been flushed when using this detach behavior.
This
# feature is still in preview mode and is not supported for
# VirtualMachineScaleSet. To force-detach a data disk update toBeDetached
# to 'true' along with setting detachOption: 'ForceDetach'. Possible
# values include: 'ForceDetach'
attr_accessor :detach_option
#
# Mapper for DataDisk class as Ruby Hash.
# This will be used for serialization/deserialization.
#
def self.mapper()
{
client_side_validation: true,
required: false,
serialized_name: 'DataDisk',
type: {
name: 'Composite',
class_name: 'DataDisk',
model_properties: {
lun: {
client_side_validation: true,
required: true,
serialized_name: 'lun',
type: {
name: 'Number'
}
},
name: {
client_side_validation: true,
required: false,
serialized_name: 'name',
type: {
name: 'String'
}
},
vhd: {
client_side_validation: true,
required: false,
serialized_name: 'vhd',
type: {
name: 'Composite',
class_name: 'VirtualHardDisk'
}
},
image: {
client_side_validation: true,
required: false,
serialized_name: 'image',
type: {
name: 'Composite',
class_name: 'VirtualHardDisk'
}
},
caching: {
client_side_validation: true,
required: false,
serialized_name: 'caching',
type: {
name: 'Enum',
module: 'CachingTypes'
}
},
write_accelerator_enabled: {
client_side_validation: true,
required: false,
serialized_name: 'writeAcceleratorEnabled',
type: {
name: 'Boolean'
}
},
create_option: {
client_side_validation: true,
required: true,
serialized_name: 'createOption',
type: {
name: 'String'
}
},
disk_size_gb: {
client_side_validation: true,
required: false,
serialized_name: 'diskSizeGB',
type: {
name: 'Number'
}
},
managed_disk: {
client_side_validation: true,
required: false,
serialized_name: 'managedDisk',
type: {
name: 'Composite',
class_name: 'ManagedDiskParameters'
}
},
to_be_detached: {
client_side_validation: true,
required: false,
serialized_name: 'toBeDetached',
type: {
name: 'Boolean'
}
},
disk_iopsread_write: {
client_side_validation: true,
required: false,
read_only: true,
serialized_name: 'diskIOPSReadWrite',
type: {
name: 'Number'
}
},
disk_mbps_read_write: {
client_side_validation: true,
required: false,
read_only: true,
serialized_name: 'diskMBpsReadWrite',
type: {
name: 'Number'
}
},
detach_option: {
client_side_validation: true,
required: false,
serialized_name: 'detachOption',
type: {
name: 'String'
}
}
}
}
}
end
end
end
end