Class: Chef::Knife::VsphereVmShow
- Inherits:
-
BaseVsphereCommand
- Object
- Bootstrap
- BaseVsphereCommand
- Chef::Knife::VsphereVmShow
- Defined in:
- lib/chef/knife/vsphere_vm_show.rb
Overview
VsphereVmShow extends the BaseVspherecommand
Instance Method Summary collapse
-
#run ⇒ Object
The main run method for vm_show.
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_show
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
# File 'lib/chef/knife/vsphere_vm_show.rb', line 21 def run $stdout.sync = true vmname = @name_args.shift if vmname.nil? show_usage fatal_exit("You must specify a virtual machine name") end if @name_args.empty? show_usage fatal_exit("You must specify a QUERY value (e.g. guest.ipAddress or network[0].name)") end vm = get_vm_by_name(vmname, get_config(:folder)) || fatal_exit("Could not find #{vmname}") out = @name_args.map do |query_string| # split QUERY by dots, and walk the object model query = query_string.split "." result = vm query.each do |part| , index = part.split(/[\[\]]/) unless result.respond_to? .to_sym fatal_exit("\"#{query_string}\" not recognized.") end result = index ? result.send()[index.to_i] : result.send() end { query_string => result } end ui.output out end |