vagrant/plugins/providers/virtualbox/action/set_name.rb

41 lines
1.2 KiB
Ruby

require "log4r"
module VagrantPlugins
module ProviderVirtualBox
module Action
class SetName
def initialize(app, env)
@logger = Log4r::Logger.new("vagrant::action::vm::setname")
@app = app
end
def call(env)
name = env[:machine].provider_config.name
# If no name was manually set, then use a default
if !name
prefix = env[:root_path].basename.to_s
prefix.gsub!(/[^-a-z0-9_]/i, "")
name = prefix + "_#{Time.now.to_i}"
end
# Verify the name is not taken
vms = env[:machine].provider.driver.read_vms
raise Vagrant::Errors::VMNameExists, :name => name if \
vms.has_key?(name) && vms[name] != env[:machine].id
if vms.has_key?(name)
@logger.info("Not setting the name because our name is already set.")
else
@logger.info("Setting the name of the VM: #{name}")
env[:ui].info(I18n.t("vagrant.actions.vm.set_name.setting_name"))
env[:machine].provider.driver.set_name(name)
end
@app.call(env)
end
end
end
end
end