# 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 # # Specifies information about the dedicated host group that the dedicated # hosts should be assigned to.

Currently, a dedicated host can # only be added to a dedicated host group at creation time. An existing # dedicated host cannot be added to another dedicated host group. # class DedicatedHostGroup < Resource include MsRestAzure # @return [Integer] Number of fault domains that the host group can span. attr_accessor :platform_fault_domain_count # @return [Array] A list of references to all # dedicated hosts in the dedicated host group. attr_accessor :hosts # @return [DedicatedHostGroupInstanceView] The dedicated host group # instance view, which has the list of instance view of the dedicated # hosts under the dedicated host group. attr_accessor :instance_view # @return [Boolean] Specifies whether virtual machines or virtual machine # scale sets can be placed automatically on the dedicated host group. # Automatic placement means resources are allocated on dedicated hosts, # that are chosen by Azure, under the dedicated host group. The value is # defaulted to 'false' when not provided.

Minimum api-version: # 2020-06-01. attr_accessor :support_automatic_placement # @return [Array] Availability Zone to use for this host group. # Only single zone is supported. The zone can be assigned only during # creation. If not provided, the group supports all zones in the region. # If provided, enforces each host in the group to be in the same zone. attr_accessor :zones # # Mapper for DedicatedHostGroup class as Ruby Hash. # This will be used for serialization/deserialization. # def self.mapper() { client_side_validation: true, required: false, serialized_name: 'DedicatedHostGroup', type: { name: 'Composite', class_name: 'DedicatedHostGroup', model_properties: { id: { client_side_validation: true, required: false, read_only: true, serialized_name: 'id', type: { name: 'String' } }, name: { client_side_validation: true, required: false, read_only: true, serialized_name: 'name', type: { name: 'String' } }, type: { client_side_validation: true, required: false, read_only: true, serialized_name: 'type', type: { name: 'String' } }, location: { client_side_validation: true, required: true, serialized_name: 'location', type: { name: 'String' } }, tags: { client_side_validation: true, required: false, serialized_name: 'tags', type: { name: 'Dictionary', value: { client_side_validation: true, required: false, serialized_name: 'StringElementType', type: { name: 'String' } } } }, platform_fault_domain_count: { client_side_validation: true, required: true, serialized_name: 'properties.platformFaultDomainCount', constraints: { InclusiveMinimum: 1 }, type: { name: 'Number' } }, hosts: { client_side_validation: true, required: false, read_only: true, serialized_name: 'properties.hosts', type: { name: 'Sequence', element: { client_side_validation: true, required: false, serialized_name: 'SubResourceReadOnlyElementType', type: { name: 'Composite', class_name: 'SubResourceReadOnly' } } } }, instance_view: { client_side_validation: true, required: false, read_only: true, serialized_name: 'properties.instanceView', type: { name: 'Composite', class_name: 'DedicatedHostGroupInstanceView' } }, support_automatic_placement: { client_side_validation: true, required: false, serialized_name: 'properties.supportAutomaticPlacement', type: { name: 'Boolean' } }, zones: { client_side_validation: true, required: false, serialized_name: 'zones', type: { name: 'Sequence', element: { client_side_validation: true, required: false, serialized_name: 'StringElementType', type: { name: 'String' } } } } } } } end end end end