# 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::V2017_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
#
# 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'
}
}
}
}
}
end
end
end
end