Class: Chef::Knife::VsphereVmDiskList
- Inherits:
-
BaseVsphereCommand
- Object
- Bootstrap
- BaseVsphereCommand
- Chef::Knife::VsphereVmDiskList
- Defined in:
- lib/chef/knife/vsphere_vm_disk_list.rb
Overview
List the disks attached to a VM VsphereVmdisklist extends the BaseVspherecommand
Instance Method Summary collapse
-
#run ⇒ Object
The main run method for vm_disk_list.
Methods inherited from BaseVsphereCommand
#choose_datastore, common_options, #conn_opts, #datacenter, #fatal_exit, #find_all_in_folder, #find_datastore, #find_datastorecluster, #find_datastores_regex, #find_device, #find_folder, #find_in_folder, #find_network, #find_pool, #find_pool_folder, #find_pools_and_clusters, #get_config, #get_password_from_stdin, #get_path_to_object, #linux?, #number_to_human_size, #password, #tcp_test_port, #tcp_test_port_vm, #traverse_folders_for_computeresources, #traverse_folders_for_dc, #traverse_folders_for_pools, #vim_connection, #windows?
Instance Method Details
#run ⇒ Object
The main run method for vm_disk_list
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 |
# File 'lib/chef/knife/vsphere_vm_disk_list.rb', line 19 def run $stdout.sync = true unless vmname = @name_args[0] show_usage fatal_exit "You must specify a virtual machine name" end vm = get_vm_by_name(vmname, get_config(:folder)) || fatal_exit("Could not find #{vmname}") disks = vm.config.hardware.device.select do |device| device.is_a? RbVmomi::VIM::VirtualDisk end disks.each do |disk| puts "%3d %20s %20s %s" % [disk.unitNumber, disk.deviceInfo.label, disk.backing.datastore.name, Filesize.from("#{disk.capacityInKB} KiB").pretty] end end |