class OCI::OsManagement::Models::ManagedInstance
Detail information for an OCI
Compute instance that is being managed
Constants
- OS_FAMILY_ENUM
- STATUS_ENUM
Attributes
Number of bug fix type updates available to be installed @return [Integer]
list of child Software Sources attached to the Managed Instance @return [Array<OCI::OsManagement::Models::SoftwareSourceId>]
[Required] OCID for the Compartment @return [String]
Information specified by the user about the managed instance @return [String]
[Required] Managed Instance identifier @return [String]
Number of enhancement type updates available to be installed @return [Integer]
[Required] OCID for the managed instance @return [String]
Indicates whether a reboot is required to complete installation of updates. @return [BOOLEAN]
Time at which the instance last booted @return [String]
Time at which the instance last checked in @return [String]
The ids of the managed instance groups of which this instance is a member.
@return [Array<OCI::OsManagement::Models::Id>]
The Operating System type of the managed instance. @return [String]
Operating System Kernel Version @return [String]
Operating System Name @return [String]
Operating System Version @return [String]
Number of non-classified updates available to be installed @return [Integer]
the parent (base) Software Source attached to the Managed Instance @return [OCI::OsManagement::Models::SoftwareSourceId]
Number of scheduled jobs associated with this instance @return [Integer]
Number of security type updates available to be installed @return [Integer]
status of the managed instance. @return [String]
Number of updates available to be installed @return [Integer]
Number of work requests associated with this instance @return [Integer]
Public Class Methods
Attribute mapping from ruby-style variable name to JSON key.
# File lib/oci/os_management/models/managed_instance.rb, line 117 def self.attribute_map { # rubocop:disable Style/SymbolLiteral 'display_name': :'displayName', 'id': :'id', 'description': :'description', 'last_checkin': :'lastCheckin', 'last_boot': :'lastBoot', 'updates_available': :'updatesAvailable', 'os_name': :'osName', 'os_version': :'osVersion', 'os_kernel_version': :'osKernelVersion', 'compartment_id': :'compartmentId', 'status': :'status', 'parent_software_source': :'parentSoftwareSource', 'child_software_sources': :'childSoftwareSources', 'managed_instance_groups': :'managedInstanceGroups', 'os_family': :'osFamily', 'is_reboot_required': :'isRebootRequired', 'security_updates_available': :'securityUpdatesAvailable', 'bug_updates_available': :'bugUpdatesAvailable', 'enhancement_updates_available': :'enhancementUpdatesAvailable', 'other_updates_available': :'otherUpdatesAvailable', 'scheduled_job_count': :'scheduledJobCount', 'work_request_count': :'workRequestCount' # rubocop:enable Style/SymbolLiteral } end
Initializes the object @param [Hash] attributes Model attributes in the form of hash @option attributes [String] :display_name The value to assign to the {#display_name} property @option attributes [String] :id The value to assign to the {#id} property @option attributes [String] :description The value to assign to the {#description} property @option attributes [String] :last_checkin The value to assign to the {#last_checkin} property @option attributes [String] :last_boot The value to assign to the {#last_boot} property @option attributes [Integer] :updates_available The value to assign to the {#updates_available} property @option attributes [String] :os_name The value to assign to the {#os_name} property @option attributes [String] :os_version The value to assign to the {#os_version} property @option attributes [String] :os_kernel_version The value to assign to the {#os_kernel_version} property @option attributes [String] :compartment_id The value to assign to the {#compartment_id} property @option attributes [String] :status The value to assign to the {#status} property @option attributes [OCI::OsManagement::Models::SoftwareSourceId] :parent_software_source The value to assign to the {#parent_software_source} property @option attributes [Array<OCI::OsManagement::Models::SoftwareSourceId>] :child_software_sources The value to assign to the {#child_software_sources} property @option attributes [Array<OCI::OsManagement::Models::Id>] :managed_instance_groups The value to assign to the {#managed_instance_groups} property @option attributes [String] :os_family The value to assign to the {#os_family} property @option attributes [BOOLEAN] :is_reboot_required The value to assign to the {#is_reboot_required} property @option attributes [Integer] :security_updates_available The value to assign to the {#security_updates_available} property @option attributes [Integer] :bug_updates_available The value to assign to the {#bug_updates_available} property @option attributes [Integer] :enhancement_updates_available The value to assign to the {#enhancement_updates_available} property @option attributes [Integer] :other_updates_available The value to assign to the {#other_updates_available} property @option attributes [Integer] :scheduled_job_count The value to assign to the {#scheduled_job_count} property @option attributes [Integer] :work_request_count The value to assign to the {#work_request_count} property
# File lib/oci/os_management/models/managed_instance.rb, line 204 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.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.id = attributes[:'id'] if attributes[:'id'] self.description = attributes[:'description'] if attributes[:'description'] self.last_checkin = attributes[:'lastCheckin'] if attributes[:'lastCheckin'] raise 'You cannot provide both :lastCheckin and :last_checkin' if attributes.key?(:'lastCheckin') && attributes.key?(:'last_checkin') self.last_checkin = attributes[:'last_checkin'] if attributes[:'last_checkin'] self.last_boot = attributes[:'lastBoot'] if attributes[:'lastBoot'] raise 'You cannot provide both :lastBoot and :last_boot' if attributes.key?(:'lastBoot') && attributes.key?(:'last_boot') self.last_boot = attributes[:'last_boot'] if attributes[:'last_boot'] self.updates_available = attributes[:'updatesAvailable'] if attributes[:'updatesAvailable'] raise 'You cannot provide both :updatesAvailable and :updates_available' if attributes.key?(:'updatesAvailable') && attributes.key?(:'updates_available') self.updates_available = attributes[:'updates_available'] if attributes[:'updates_available'] self.os_name = attributes[:'osName'] if attributes[:'osName'] raise 'You cannot provide both :osName and :os_name' if attributes.key?(:'osName') && attributes.key?(:'os_name') self.os_name = attributes[:'os_name'] if attributes[:'os_name'] self.os_version = attributes[:'osVersion'] if attributes[:'osVersion'] raise 'You cannot provide both :osVersion and :os_version' if attributes.key?(:'osVersion') && attributes.key?(:'os_version') self.os_version = attributes[:'os_version'] if attributes[:'os_version'] self.os_kernel_version = attributes[:'osKernelVersion'] if attributes[:'osKernelVersion'] raise 'You cannot provide both :osKernelVersion and :os_kernel_version' if attributes.key?(:'osKernelVersion') && attributes.key?(:'os_kernel_version') self.os_kernel_version = attributes[:'os_kernel_version'] if attributes[:'os_kernel_version'] 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.status = attributes[:'status'] if attributes[:'status'] self.parent_software_source = attributes[:'parentSoftwareSource'] if attributes[:'parentSoftwareSource'] raise 'You cannot provide both :parentSoftwareSource and :parent_software_source' if attributes.key?(:'parentSoftwareSource') && attributes.key?(:'parent_software_source') self.parent_software_source = attributes[:'parent_software_source'] if attributes[:'parent_software_source'] self.child_software_sources = attributes[:'childSoftwareSources'] if attributes[:'childSoftwareSources'] raise 'You cannot provide both :childSoftwareSources and :child_software_sources' if attributes.key?(:'childSoftwareSources') && attributes.key?(:'child_software_sources') self.child_software_sources = attributes[:'child_software_sources'] if attributes[:'child_software_sources'] self.managed_instance_groups = attributes[:'managedInstanceGroups'] if attributes[:'managedInstanceGroups'] raise 'You cannot provide both :managedInstanceGroups and :managed_instance_groups' if attributes.key?(:'managedInstanceGroups') && attributes.key?(:'managed_instance_groups') self.managed_instance_groups = attributes[:'managed_instance_groups'] if attributes[:'managed_instance_groups'] self.os_family = attributes[:'osFamily'] if attributes[:'osFamily'] raise 'You cannot provide both :osFamily and :os_family' if attributes.key?(:'osFamily') && attributes.key?(:'os_family') self.os_family = attributes[:'os_family'] if attributes[:'os_family'] self.is_reboot_required = attributes[:'isRebootRequired'] unless attributes[:'isRebootRequired'].nil? raise 'You cannot provide both :isRebootRequired and :is_reboot_required' if attributes.key?(:'isRebootRequired') && attributes.key?(:'is_reboot_required') self.is_reboot_required = attributes[:'is_reboot_required'] unless attributes[:'is_reboot_required'].nil? self.security_updates_available = attributes[:'securityUpdatesAvailable'] if attributes[:'securityUpdatesAvailable'] raise 'You cannot provide both :securityUpdatesAvailable and :security_updates_available' if attributes.key?(:'securityUpdatesAvailable') && attributes.key?(:'security_updates_available') self.security_updates_available = attributes[:'security_updates_available'] if attributes[:'security_updates_available'] self.bug_updates_available = attributes[:'bugUpdatesAvailable'] if attributes[:'bugUpdatesAvailable'] raise 'You cannot provide both :bugUpdatesAvailable and :bug_updates_available' if attributes.key?(:'bugUpdatesAvailable') && attributes.key?(:'bug_updates_available') self.bug_updates_available = attributes[:'bug_updates_available'] if attributes[:'bug_updates_available'] self.enhancement_updates_available = attributes[:'enhancementUpdatesAvailable'] if attributes[:'enhancementUpdatesAvailable'] raise 'You cannot provide both :enhancementUpdatesAvailable and :enhancement_updates_available' if attributes.key?(:'enhancementUpdatesAvailable') && attributes.key?(:'enhancement_updates_available') self.enhancement_updates_available = attributes[:'enhancement_updates_available'] if attributes[:'enhancement_updates_available'] self.other_updates_available = attributes[:'otherUpdatesAvailable'] if attributes[:'otherUpdatesAvailable'] raise 'You cannot provide both :otherUpdatesAvailable and :other_updates_available' if attributes.key?(:'otherUpdatesAvailable') && attributes.key?(:'other_updates_available') self.other_updates_available = attributes[:'other_updates_available'] if attributes[:'other_updates_available'] self.scheduled_job_count = attributes[:'scheduledJobCount'] if attributes[:'scheduledJobCount'] raise 'You cannot provide both :scheduledJobCount and :scheduled_job_count' if attributes.key?(:'scheduledJobCount') && attributes.key?(:'scheduled_job_count') self.scheduled_job_count = attributes[:'scheduled_job_count'] if attributes[:'scheduled_job_count'] self.work_request_count = attributes[:'workRequestCount'] if attributes[:'workRequestCount'] raise 'You cannot provide both :workRequestCount and :work_request_count' if attributes.key?(:'workRequestCount') && attributes.key?(:'work_request_count') self.work_request_count = attributes[:'work_request_count'] if attributes[:'work_request_count'] end
Attribute type mapping.
# File lib/oci/os_management/models/managed_instance.rb, line 147 def self.swagger_types { # rubocop:disable Style/SymbolLiteral 'display_name': :'String', 'id': :'String', 'description': :'String', 'last_checkin': :'String', 'last_boot': :'String', 'updates_available': :'Integer', 'os_name': :'String', 'os_version': :'String', 'os_kernel_version': :'String', 'compartment_id': :'String', 'status': :'String', 'parent_software_source': :'OCI::OsManagement::Models::SoftwareSourceId', 'child_software_sources': :'Array<OCI::OsManagement::Models::SoftwareSourceId>', 'managed_instance_groups': :'Array<OCI::OsManagement::Models::Id>', 'os_family': :'String', 'is_reboot_required': :'BOOLEAN', 'security_updates_available': :'Integer', 'bug_updates_available': :'Integer', 'enhancement_updates_available': :'Integer', 'other_updates_available': :'Integer', 'scheduled_job_count': :'Integer', 'work_request_count': :'Integer' # rubocop:enable Style/SymbolLiteral } end
Public Instance Methods
Checks equality by comparing each attribute. @param [Object] other the other object to be compared
# File lib/oci/os_management/models/managed_instance.rb, line 364 def ==(other) return true if equal?(other) self.class == other.class && display_name == other.display_name && id == other.id && description == other.description && last_checkin == other.last_checkin && last_boot == other.last_boot && updates_available == other.updates_available && os_name == other.os_name && os_version == other.os_version && os_kernel_version == other.os_kernel_version && compartment_id == other.compartment_id && status == other.status && parent_software_source == other.parent_software_source && child_software_sources == other.child_software_sources && managed_instance_groups == other.managed_instance_groups && os_family == other.os_family && is_reboot_required == other.is_reboot_required && security_updates_available == other.security_updates_available && bug_updates_available == other.bug_updates_available && enhancement_updates_available == other.enhancement_updates_available && other_updates_available == other.other_updates_available && scheduled_job_count == other.scheduled_job_count && work_request_count == other.work_request_count end
Builds the object from hash @param [Hash] attributes Model attributes in the form of hash @return [Object] Returns the model itself
# File lib/oci/os_management/models/managed_instance.rb, line 415 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
@see the `==` method @param [Object] other the other object to be compared
# File lib/oci/os_management/models/managed_instance.rb, line 395 def eql?(other) self == other end
Calculates hash code according to all attributes. @return [Fixnum] Hash code
# File lib/oci/os_management/models/managed_instance.rb, line 404 def hash [display_name, id, description, last_checkin, last_boot, updates_available, os_name, os_version, os_kernel_version, compartment_id, status, parent_software_source, child_software_sources, managed_instance_groups, os_family, is_reboot_required, security_updates_available, bug_updates_available, enhancement_updates_available, other_updates_available, scheduled_job_count, work_request_count].hash end
Custom attribute writer method checking allowed values (enum). @param [Object] os_family
Object
to be assigned
# File lib/oci/os_management/models/managed_instance.rb, line 348 def os_family=(os_family) # rubocop:disable Style/ConditionalAssignment if os_family && !OS_FAMILY_ENUM.include?(os_family) OCI.logger.debug("Unknown value for 'os_family' [" + os_family + "]. Mapping to 'OS_FAMILY_UNKNOWN_ENUM_VALUE'") if OCI.logger @os_family = OS_FAMILY_UNKNOWN_ENUM_VALUE else @os_family = os_family end # rubocop:enable Style/ConditionalAssignment end
Custom attribute writer method checking allowed values (enum). @param [Object] status Object
to be assigned
# File lib/oci/os_management/models/managed_instance.rb, line 335 def status=(status) # rubocop:disable Style/ConditionalAssignment if status && !STATUS_ENUM.include?(status) OCI.logger.debug("Unknown value for 'status' [" + status + "]. Mapping to 'STATUS_UNKNOWN_ENUM_VALUE'") if OCI.logger @status = STATUS_UNKNOWN_ENUM_VALUE else @status = status end # rubocop:enable Style/ConditionalAssignment end
Returns the object in the form of hash @return [Hash] Returns the object in the form of hash
# File lib/oci/os_management/models/managed_instance.rb, line 448 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
Returns the string representation of the object @return [String] String presentation of the object
# File lib/oci/os_management/models/managed_instance.rb, line 442 def to_s to_hash.to_s end
Private Instance Methods
Outputs non-array value in the form of hash For object, use to_hash. Otherwise, just return the value @param [Object] value Any valid value @return [Hash] Returns the value in the form of hash
# File lib/oci/os_management/models/managed_instance.rb, line 465 def _to_hash(value) if value.is_a?(Array) value.compact.map { |v| _to_hash(v) } elsif value.is_a?(Hash) {}.tap do |hash| value.each { |k, v| hash[k] = _to_hash(v) } end elsif value.respond_to? :to_hash value.to_hash else value end end