examples/shared_samples/hypervisor_manager.rb
# (C) Copyright 2021 Hewlett Packard Enterprise Development LP
#
# Licensed under the Apache License, Version 2.0 (the "License");
# You may not use this file except in compliance with the License.
# You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software distributed
# under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
# CONDITIONS OF ANY KIND, either express or implied. See the License for the
# specific language governing permissions and limitations under the License.
require_relative '../_client' # Gives access to @client
# Example: Create/Update/Delete hypervisor manager
# NOTE: This will create a hypervisor manager named 'vcenter.corp.com', update it and then delete it.
#
# Supported Variants:
# - C7000 and Synergy for all API versions
raise 'ERROR: Must set @hypervisor_manager_ip in _client.rb' unless @hypervisor_manager_ip
raise 'ERROR: Must set @hypervisor_manager_username in _client.rb' unless @hypervisor_manager_username
raise 'ERROR: Must set @hypervisor_manager_password in _client.rb' unless @hypervisor_manager_password
# Resource Class used in this sample
server_certificate_class = OneviewSDK.resource_named('ServerCertificate', @client.api_version)
hypervisor_manager_class = OneviewSDK.resource_named('HypervisorManager', @client.api_version)
options = {
name: @hypervisor_manager_ip,
username: @hypervisor_manager_username,
password: @hypervisor_manager_password
}
hm = hypervisor_manager_class.new(@client, options)
# Find recently created hypervisor manager by name
matches = hypervisor_manager_class.find_by(@client, name: hm[:name])
hm2 = matches.first
if hm2
puts "\nFound hypervisor-manager by name: '#{hm2[:name]}'.\n uri = '#{hm2[:uri]}'"
end
hm.create! unless hm2
puts "\nCreated hypervisor-manager '#{hm[:name]}' sucessfully.\n uri = '#{hm[:uri]}'"
# Retrieve recently created hypervisor manager
hm3 = hypervisor_manager_class.new(@client, name: hm[:name])
hm3.retrieve!
puts "\nRetrieved hypervisor-manager data by name: '#{hm3[:name]}'.\n uri = '#{hm3[:uri]}'"
# Update hypervisor manager registration
attribute = { name: @hypervisor_manager_ip }
query_param = {}
if @client.api_version >= 2600
force = true
query_param = { force: force }
end
hm3.update(attribute, query_param)
puts "\nUpdated hypervisor-manager: '#{hm3[:name]}'.\n uri = '#{hm3[:uri]}'"
puts "with attribute: #{attribute}"
# Example: List all hypervisor managers certain attributes
attributes = { name: @hypervisor_manager_ip }
puts "\nHypervisor manager with #{attributes}"
hypervisor_manager_class.find_by(@client, attributes).each do |hypervisor_manager|
puts " #{hypervisor_manager[:name]}"
end
# Delete this hypervisor manager
hm3.delete
puts "\nSucessfully deleted hypervisor-manager '#{hm[:name]}'."
# Gets certificates from remote IP
puts 'Fetching Certificate:-'
certificate = server_certificate_class.new(@client)
certificate.data['remoteIp'] = @hypervisor_manager_ip
# Imports the certificates
puts 'Importing the certificate:- '
item = server_certificate_class.new(@client, aliasName: @hypervisor_manager_ip)
item.data['certificateDetails'] = []
item.data['certificateDetails'][0] = {
'type' => certificate.get_certificate['certificateDetails'][0]['type'],
'base64Data' => certificate.get_certificate['certificateDetails'][0]['base64Data']
}
puts 'Imported successfully.' if item.import
# Created HypervisorManager to ensure continuity for automation script
hm4 = hypervisor_manager_class.find_by(@client, name: hm[:name]).first
hm5 = hypervisor_manager_class.new(@client, options) unless hm4
hm5.create! unless hm4
puts "\nCreated hypervisor-manager '#{hm[:name]}' sucessfully.\n uri = '#{hm[:uri]}'" unless hm4