2018-08-02 18:01:36 +00:00
|
|
|
require "json"
|
|
|
|
|
|
|
|
module VagrantPlugins
|
|
|
|
module CommandUp
|
|
|
|
# Stores metadata information about the box used
|
|
|
|
# for the current guest. This allows Vagrant to
|
|
|
|
# determine the box currently in use when the
|
|
|
|
# Vagrantfile is modified with a new box name or
|
|
|
|
# version while the guest still exists.
|
|
|
|
class StoreBoxMetadata
|
|
|
|
def initialize(app, env)
|
|
|
|
@app = app
|
2018-08-17 16:39:34 +00:00
|
|
|
@logger = Log4r::Logger.new("vagrant::up::storeboxmetadata")
|
2018-08-02 18:01:36 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def call(env)
|
2018-08-17 16:39:34 +00:00
|
|
|
if env[:machine].box
|
|
|
|
box = env[:machine].box
|
|
|
|
box_meta = {
|
|
|
|
name: box.name,
|
|
|
|
version: box.version,
|
|
|
|
provider: box.provider,
|
|
|
|
directory: box.directory.sub(Vagrant.user_data_path.to_s + "/", "")
|
|
|
|
}
|
|
|
|
meta_file = env[:machine].data_dir.join("box_meta")
|
|
|
|
@logger.debug("Writing box metadata file to #{meta_file}")
|
|
|
|
File.open(meta_file.to_s, "w+") do |file|
|
|
|
|
file.write(JSON.dump(box_meta))
|
|
|
|
end
|
|
|
|
else
|
|
|
|
@logger.debug("No box data found for #{env[:machine].name} with provider #{env[:machine].provider_name}")
|
2018-08-02 18:01:36 +00:00
|
|
|
end
|
|
|
|
@app.call(env)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|