2011-12-17 19:53:26 +00:00
|
|
|
require 'optparse'
|
|
|
|
|
2012-04-19 20:59:48 +00:00
|
|
|
module VagrantPlugins
|
|
|
|
module CommandProvision
|
2012-06-26 23:18:02 +00:00
|
|
|
class Command < Vagrant.plugin("1", :command)
|
2010-08-25 06:27:08 +00:00
|
|
|
def execute
|
2011-12-17 19:53:26 +00:00
|
|
|
options = {}
|
|
|
|
|
|
|
|
opts = OptionParser.new do |opts|
|
|
|
|
opts.banner = "Usage: vagrant provision [vm-name]"
|
|
|
|
end
|
|
|
|
|
|
|
|
# Parse the options
|
|
|
|
argv = parse_options(opts)
|
|
|
|
return if !argv
|
|
|
|
|
|
|
|
# Go over each VM and provision!
|
|
|
|
@logger.debug("'provision' each target VM...")
|
2012-03-11 22:32:17 +00:00
|
|
|
with_target_vms(argv) do |vm|
|
2012-04-19 20:59:48 +00:00
|
|
|
|
2011-07-30 16:58:29 +00:00
|
|
|
if vm.created?
|
2012-01-06 07:12:28 +00:00
|
|
|
if vm.state == :running
|
2011-12-17 19:53:26 +00:00
|
|
|
@logger.info("Provisioning: #{vm.name}")
|
2011-07-30 16:58:29 +00:00
|
|
|
vm.provision
|
|
|
|
else
|
2011-12-17 19:53:26 +00:00
|
|
|
@logger.info("#{vm.name} not running. Not provisioning.")
|
|
|
|
vm.ui.info I18n.t("vagrant.commands.common.vm_not_running")
|
2011-07-30 16:58:29 +00:00
|
|
|
end
|
2010-08-25 06:27:08 +00:00
|
|
|
else
|
2011-12-17 19:53:26 +00:00
|
|
|
@logger.info("#{vm.name} not created. Not provisioning.")
|
|
|
|
vm.ui.info I18n.t("vagrant.commands.common.vm_not_created")
|
2010-08-25 06:27:08 +00:00
|
|
|
end
|
|
|
|
end
|
2012-03-23 15:07:35 +00:00
|
|
|
|
|
|
|
# Success, exit status 0
|
|
|
|
0
|
|
|
|
end
|
2010-08-25 06:27:08 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|