Class: OCI::Core::Models::ComputeCapacityReservation

Inherits:
Object
  • Object
show all
Defined in:
lib/oci/core/models/compute_capacity_reservation.rb

Overview

A template that defines the settings to use when creating compute capacity reservations.

Constant Summary collapse

LIFECYCLE_STATE_ENUM =
[
  LIFECYCLE_STATE_ACTIVE = 'ACTIVE'.freeze,
  LIFECYCLE_STATE_CREATING = 'CREATING'.freeze,
  LIFECYCLE_STATE_UPDATING = 'UPDATING'.freeze,
  LIFECYCLE_STATE_MOVING = 'MOVING'.freeze,
  LIFECYCLE_STATE_DELETED = 'DELETED'.freeze,
  LIFECYCLE_STATE_DELETING = 'DELETING'.freeze,
  LIFECYCLE_STATE_UNKNOWN_ENUM_VALUE = 'UNKNOWN_ENUM_VALUE'.freeze
].freeze

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(attributes = {}) ⇒ ComputeCapacityReservation

Initializes the object

Parameters:

  • attributes (Hash) (defaults to: {})

    Model attributes in the form of hash

Options Hash (attributes):



171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 171

def initialize(attributes = {})
  return unless attributes.is_a?(Hash)

  # convert string to symbol for hash key
  attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }

  self.availability_domain = attributes[:'availabilityDomain'] if attributes[:'availabilityDomain']

  raise 'You cannot provide both :availabilityDomain and :availability_domain' if attributes.key?(:'availabilityDomain') && attributes.key?(:'availability_domain')

  self.availability_domain = attributes[:'availability_domain'] if attributes[:'availability_domain']

  self.compartment_id = attributes[:'compartmentId'] if attributes[:'compartmentId']

  raise 'You cannot provide both :compartmentId and :compartment_id' if attributes.key?(:'compartmentId') && attributes.key?(:'compartment_id')

  self.compartment_id = attributes[:'compartment_id'] if attributes[:'compartment_id']

  self.defined_tags = attributes[:'definedTags'] if attributes[:'definedTags']

  raise 'You cannot provide both :definedTags and :defined_tags' if attributes.key?(:'definedTags') && attributes.key?(:'defined_tags')

  self.defined_tags = attributes[:'defined_tags'] if attributes[:'defined_tags']

  self.display_name = attributes[:'displayName'] if attributes[:'displayName']

  raise 'You cannot provide both :displayName and :display_name' if attributes.key?(:'displayName') && attributes.key?(:'display_name')

  self.display_name = attributes[:'display_name'] if attributes[:'display_name']

  self.freeform_tags = attributes[:'freeformTags'] if attributes[:'freeformTags']

  raise 'You cannot provide both :freeformTags and :freeform_tags' if attributes.key?(:'freeformTags') && attributes.key?(:'freeform_tags')

  self.freeform_tags = attributes[:'freeform_tags'] if attributes[:'freeform_tags']

  self.id = attributes[:'id'] if attributes[:'id']

  self.is_default_reservation = attributes[:'isDefaultReservation'] unless attributes[:'isDefaultReservation'].nil?
  self.is_default_reservation = false if is_default_reservation.nil? && !attributes.key?(:'isDefaultReservation') # rubocop:disable Style/StringLiterals

  raise 'You cannot provide both :isDefaultReservation and :is_default_reservation' if attributes.key?(:'isDefaultReservation') && attributes.key?(:'is_default_reservation')

  self.is_default_reservation = attributes[:'is_default_reservation'] unless attributes[:'is_default_reservation'].nil?
  self.is_default_reservation = false if is_default_reservation.nil? && !attributes.key?(:'isDefaultReservation') && !attributes.key?(:'is_default_reservation') # rubocop:disable Style/StringLiterals

  self.instance_reservation_configs = attributes[:'instanceReservationConfigs'] if attributes[:'instanceReservationConfigs']

  raise 'You cannot provide both :instanceReservationConfigs and :instance_reservation_configs' if attributes.key?(:'instanceReservationConfigs') && attributes.key?(:'instance_reservation_configs')

  self.instance_reservation_configs = attributes[:'instance_reservation_configs'] if attributes[:'instance_reservation_configs']

  self.lifecycle_state = attributes[:'lifecycleState'] if attributes[:'lifecycleState']

  raise 'You cannot provide both :lifecycleState and :lifecycle_state' if attributes.key?(:'lifecycleState') && attributes.key?(:'lifecycle_state')

  self.lifecycle_state = attributes[:'lifecycle_state'] if attributes[:'lifecycle_state']

  self.reserved_instance_count = attributes[:'reservedInstanceCount'] if attributes[:'reservedInstanceCount']

  raise 'You cannot provide both :reservedInstanceCount and :reserved_instance_count' if attributes.key?(:'reservedInstanceCount') && attributes.key?(:'reserved_instance_count')

  self.reserved_instance_count = attributes[:'reserved_instance_count'] if attributes[:'reserved_instance_count']

  self.time_updated = attributes[:'timeUpdated'] if attributes[:'timeUpdated']

  raise 'You cannot provide both :timeUpdated and :time_updated' if attributes.key?(:'timeUpdated') && attributes.key?(:'time_updated')

  self.time_updated = attributes[:'time_updated'] if attributes[:'time_updated']

  self.time_created = attributes[:'timeCreated'] if attributes[:'timeCreated']

  raise 'You cannot provide both :timeCreated and :time_created' if attributes.key?(:'timeCreated') && attributes.key?(:'time_created')

  self.time_created = attributes[:'time_created'] if attributes[:'time_created']

  self.used_instance_count = attributes[:'usedInstanceCount'] if attributes[:'usedInstanceCount']

  raise 'You cannot provide both :usedInstanceCount and :used_instance_count' if attributes.key?(:'usedInstanceCount') && attributes.key?(:'used_instance_count')

  self.used_instance_count = attributes[:'used_instance_count'] if attributes[:'used_instance_count']
end

Instance Attribute Details

#availability_domainString

[Required] The availability domain of the compute capacity reservation.

Example: Uocm:PHX-AD-1

Returns:

  • (String)


28
29
30
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 28

def availability_domain
  @availability_domain
end

#compartment_idString

[Required] The OCID of the compartment containing the compute capacity reservation.

Returns:

  • (String)


34
35
36
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 34

def compartment_id
  @compartment_id
end

#defined_tagsHash<String, Hash<String, Object>>

Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.

Example: {\"Operations\": {\"CostCenter\": \"42\"}}

Returns:

  • (Hash<String, Hash<String, Object>>)


42
43
44
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 42

def defined_tags
  @defined_tags
end

#display_nameString

A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.

Returns:

  • (String)


48
49
50
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 48

def display_name
  @display_name
end

#freeform_tagsHash<String, String>

Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags.

Example: {\"Department\": \"Finance\"}

Returns:

  • (Hash<String, String>)


56
57
58
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 56

def freeform_tags
  @freeform_tags
end

#idString

[Required] The OCID of the compute capacity reservation.

Returns:

  • (String)


60
61
62
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 60

def id
  @id
end

#instance_reservation_configsArray<OCI::Core::Models::InstanceReservationConfig>

The capacity configurations for the capacity reservation.

To use the reservation for the desired shape, specify the shape, count, and optionally the fault domain where you want this configuration.



74
75
76
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 74

def instance_reservation_configs
  @instance_reservation_configs
end

#is_default_reservationBOOLEAN

Whether this capacity reservation is the default. For more information, see Capacity Reservations.

Returns:

  • (BOOLEAN)


66
67
68
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 66

def is_default_reservation
  @is_default_reservation
end

#lifecycle_stateString

[Required] The current state of the compute capacity reservation.

Returns:

  • (String)


78
79
80
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 78

def lifecycle_state
  @lifecycle_state
end

#reserved_instance_countInteger

The number of instances for which capacity will be held with this compute capacity reservation. This number is the sum of the values of the reservedCount fields for all of the instance capacity configurations under this reservation. The purpose of this field is to calculate the percentage usage of the reservation.

Returns:

  • (Integer)


86
87
88
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 86

def reserved_instance_count
  @reserved_instance_count
end

#time_createdDateTime

[Required] The date and time the compute capacity reservation was created, in the format defined by RFC3339.

Example: 2016-08-25T21:10:29.600Z

Returns:

  • (DateTime)


100
101
102
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 100

def time_created
  @time_created
end

#time_updatedDateTime

The date and time the compute capacity reservation was updated, in the format defined by RFC3339.

Example: 2016-08-25T21:10:29.600Z

Returns:

  • (DateTime)


93
94
95
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 93

def time_updated
  @time_updated
end

#used_instance_countInteger

The total number of instances currently consuming space in this compute capacity reservation. This number is the sum of the values of the usedCount fields for all of the instance capacity configurations under this reservation. The purpose of this field is to calculate the percentage usage of the reservation.

Returns:

  • (Integer)


108
109
110
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 108

def used_instance_count
  @used_instance_count
end

Class Method Details

.attribute_mapObject

Attribute mapping from ruby-style variable name to JSON key.



111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 111

def self.attribute_map
  {
    # rubocop:disable Style/SymbolLiteral
    'availability_domain': :'availabilityDomain',
    'compartment_id': :'compartmentId',
    'defined_tags': :'definedTags',
    'display_name': :'displayName',
    'freeform_tags': :'freeformTags',
    'id': :'id',
    'is_default_reservation': :'isDefaultReservation',
    'instance_reservation_configs': :'instanceReservationConfigs',
    'lifecycle_state': :'lifecycleState',
    'reserved_instance_count': :'reservedInstanceCount',
    'time_updated': :'timeUpdated',
    'time_created': :'timeCreated',
    'used_instance_count': :'usedInstanceCount'
    # rubocop:enable Style/SymbolLiteral
  }
end

.swagger_typesObject

Attribute type mapping.



132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 132

def self.swagger_types
  {
    # rubocop:disable Style/SymbolLiteral
    'availability_domain': :'String',
    'compartment_id': :'String',
    'defined_tags': :'Hash<String, Hash<String, Object>>',
    'display_name': :'String',
    'freeform_tags': :'Hash<String, String>',
    'id': :'String',
    'is_default_reservation': :'BOOLEAN',
    'instance_reservation_configs': :'Array<OCI::Core::Models::InstanceReservationConfig>',
    'lifecycle_state': :'String',
    'reserved_instance_count': :'Integer',
    'time_updated': :'DateTime',
    'time_created': :'DateTime',
    'used_instance_count': :'Integer'
    # rubocop:enable Style/SymbolLiteral
  }
end

Instance Method Details

#==(other) ⇒ Object

Checks equality by comparing each attribute.

Parameters:

  • other (Object)

    the other object to be compared



274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 274

def ==(other)
  return true if equal?(other)

  self.class == other.class &&
    availability_domain == other.availability_domain &&
    compartment_id == other.compartment_id &&
    defined_tags == other.defined_tags &&
    display_name == other.display_name &&
    freeform_tags == other.freeform_tags &&
    id == other.id &&
    is_default_reservation == other.is_default_reservation &&
    instance_reservation_configs == other.instance_reservation_configs &&
    lifecycle_state == other.lifecycle_state &&
    reserved_instance_count == other.reserved_instance_count &&
    time_updated == other.time_updated &&
    time_created == other.time_created &&
    used_instance_count == other.used_instance_count
end

#build_from_hash(attributes) ⇒ Object

Builds the object from hash

Parameters:

  • attributes (Hash)

    Model attributes in the form of hash

Returns:

  • (Object)

    Returns the model itself



316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 316

def build_from_hash(attributes)
  return nil unless attributes.is_a?(Hash)

  self.class.swagger_types.each_pair do |key, type|
    if type =~ /^Array<(.*)>/i
      # check to ensure the input is an array given that the the attribute
      # is documented as an array but the input is not
      if attributes[self.class.attribute_map[key]].is_a?(Array)
        public_method("#{key}=").call(
          attributes[self.class.attribute_map[key]]
            .map { |v| OCI::Internal::Util.convert_to_type(Regexp.last_match(1), v) }
        )
      end
    elsif !attributes[self.class.attribute_map[key]].nil?
      public_method("#{key}=").call(
        OCI::Internal::Util.convert_to_type(type, attributes[self.class.attribute_map[key]])
      )
    end
    # or else data not found in attributes(hash), not an issue as the data can be optional
  end

  self
end

#eql?(other) ⇒ Boolean

Parameters:

  • other (Object)

    the other object to be compared

Returns:

  • (Boolean)

See Also:

  • `==` method


296
297
298
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 296

def eql?(other)
  self == other
end

#hashFixnum

Calculates hash code according to all attributes.

Returns:

  • (Fixnum)

    Hash code



305
306
307
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 305

def hash
  [availability_domain, compartment_id, defined_tags, display_name, freeform_tags, id, is_default_reservation, instance_reservation_configs, lifecycle_state, reserved_instance_count, time_updated, time_created, used_instance_count].hash
end

#to_hashHash

Returns the object in the form of hash

Returns:

  • (Hash)

    Returns the object in the form of hash



349
350
351
352
353
354
355
356
357
358
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 349

def to_hash
  hash = {}
  self.class.attribute_map.each_pair do |attr, param|
    value = public_method(attr).call
    next if value.nil? && !instance_variable_defined?("@#{attr}")

    hash[param] = _to_hash(value)
  end
  hash
end

#to_sString

Returns the string representation of the object

Returns:

  • (String)

    String presentation of the object



343
344
345
# File 'lib/oci/core/models/compute_capacity_reservation.rb', line 343

def to_s
  to_hash.to_s
end