Class: Vagrant::Action::Builtin::HandleBoxUrl
- Inherits:
-
Object
- Object
- Vagrant::Action::Builtin::HandleBoxUrl
- Defined in:
- lib/vagrant/action/builtin/handle_box_url.rb
Overview
This built-in middleware handles the ‘box_url` setting, downloading the box if necessary. You should place this early in your middleware sequence for a provider after configuration validation but before you attempt to use any box.
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app, env) ⇒ HandleBoxUrl
constructor
A new instance of HandleBoxUrl.
Constructor Details
#initialize(app, env) ⇒ HandleBoxUrl
Returns a new instance of HandleBoxUrl.
9 10 11 |
# File 'lib/vagrant/action/builtin/handle_box_url.rb', line 9 def initialize(app, env) @app = app end |
Instance Method Details
#call(env) ⇒ Object
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 |
# File 'lib/vagrant/action/builtin/handle_box_url.rb', line 13 def call(env) if !env[:machine].box # We can assume a box URL is set because the Vagrantfile # validation should do this for us. If not, though, we do # raise a terrible runtime error. box_name = env[:machine].config.vm.box box_url = env[:machine].config.vm.box_url # Add the box then reload the box collection so that it becomes # aware of it. env[:ui].info I18n.t( "vagrant.actions.vm.check_box.not_found", :name => box_name, :provider => env[:machine].provider_name) env[:action_runner].run(Vagrant::Action.action_box_add, { :box_name => box_name, :box_provider => env[:machine].provider_name, :box_url => box_url }) # Reload the environment and set the VM to be the new loaded VM. env[:machine] = env[:machine].env.machine( env[:machine].name, env[:machine].provider_name, true) end @app.call(env) end |