Class: VagrantPlugins::ProviderZone::Command::Console

Inherits:
Object
  • Object
show all
Defined in:
lib/vagrant-zones/command/console.rb

Overview

This is used to start a console to the zone via WebVNC, VNC or Serial/Telnet

Instance Method Summary collapse

Constructor Details

#initialize(argv, env) ⇒ Console

Returns a new instance of Console.



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
# File 'lib/vagrant-zones/command/console.rb', line 8

def initialize(argv, env)
  @main_args, @sub_command, @sub_args = split_main_and_subcommand(argv)

  @subcommands = Vagrant::Registry.new
  @subcommands.register(:vnc) do
    require File.expand_path('vnc_console', __dir__)
    VNCConsole
  end
  @subcommands.register(:zlogin) do
    require File.expand_path('zlogin_console', __dir__)
    ZloginConsole
  end
  @subcommands.register(:webvnc) do
    require File.expand_path('webvnc_console', __dir__)
    WebVNCConsole
  end
  super(argv, env)
end

Instance Method Details

#executeObject



27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# File 'lib/vagrant-zones/command/console.rb', line 27

def execute
  if @main_args.include?('-h') || @main_args.include?('--help')
    # Print the help for all the vagrant-zones commands.
    return help
  end

  with_target_vms(@main_args, provider: :zone) do |machine|
    @sub_command = machine.provider_config.console.to_sym unless machine.provider_config.console.nil? || @sub_command
    command_class = @subcommands.get(@sub_command.to_sym) if @sub_command
    @logger.debug("Invoking command class: #{command_class} #{machine.provider_config.console.to_sym}")
    return help if !command_class || !@sub_command

    # Initialize and execute the command class
    command_class.new(@sub_args, @env).execute
  end
end

#helpObject



44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# File 'lib/vagrant-zones/command/console.rb', line 44

def help
  opts = OptionParser.new do |subopts|
    subopts.banner = 'Usage: vagrant zone console <subcommand> [<args>]'
    subopts.separator ''
    subopts.separator 'Available subcommands:'
    # Add the available subcommands as separators in order to print them
    # out as well.
    keys = []
    @subcommands.each { |(key, _value)| keys << key.to_s }
    keys.sort.each do |key|
      subopts.separator "     #{key}"
    end
    subopts.separator 'For help on any individual subcommand run `vagrant zone console <subcommand> -h`'
  end
  @env.ui.info(opts.help, :prefix => false)
end