ProvisionExt is not an action!
This commit is contained in:
parent
18ff01907e
commit
b50374162a
3 changed files with 70 additions and 72 deletions
|
@ -1,70 +0,0 @@
|
||||||
require_relative '../bucket'
|
|
||||||
|
|
||||||
module VagrantPlugins
|
|
||||||
module Cachier
|
|
||||||
module Action
|
|
||||||
module ProvisionExt
|
|
||||||
def self.included(base)
|
|
||||||
base.class_eval do
|
|
||||||
def cachier_debug(msg)
|
|
||||||
@logger.debug "[CACHIER] #{msg}"
|
|
||||||
end
|
|
||||||
|
|
||||||
alias :old_call :call
|
|
||||||
def call(env)
|
|
||||||
return old_call(env) unless env[:machine].config.cache.enabled?
|
|
||||||
|
|
||||||
@env = env
|
|
||||||
|
|
||||||
FileUtils.mkdir_p(cache_root.to_s) unless cache_root.exist?
|
|
||||||
|
|
||||||
nfs_flag = env[:machine].config.cache.enable_nfs
|
|
||||||
env[:machine].config.vm.synced_folder cache_root, '/tmp/vagrant-cache', id: "vagrant-cache", nfs: nfs_flag
|
|
||||||
|
|
||||||
env[:cache_dirs] = []
|
|
||||||
|
|
||||||
old_call(env)
|
|
||||||
|
|
||||||
configure_cache_buckets
|
|
||||||
end
|
|
||||||
|
|
||||||
alias :old_run_provisioner :run_provisioner
|
|
||||||
def run_provisioner(*args)
|
|
||||||
configure_cache_buckets
|
|
||||||
old_run_provisioner(*args)
|
|
||||||
end
|
|
||||||
|
|
||||||
def configure_cache_buckets
|
|
||||||
if @env[:machine].config.cache.auto_detect
|
|
||||||
Bucket.auto_detect(@env)
|
|
||||||
end
|
|
||||||
|
|
||||||
return unless @env[:machine].config.cache.buckets.any?
|
|
||||||
|
|
||||||
@env[:ui].info 'Configuring cache buckets...'
|
|
||||||
cache_config = @env[:machine].config.cache
|
|
||||||
cache_config.buckets.each do |bucket_name, configs|
|
|
||||||
cachier_debug "Installing #{bucket_name} with configs #{configs.inspect}"
|
|
||||||
Bucket.install(bucket_name, @env, configs)
|
|
||||||
end
|
|
||||||
|
|
||||||
data_file = @env[:machine].data_dir.join('cache_dirs')
|
|
||||||
data_file.open('w') { |f| f.print @env[:cache_dirs].uniq.join("\n") }
|
|
||||||
end
|
|
||||||
|
|
||||||
def cache_root
|
|
||||||
@cache_root ||= case @env[:machine].config.cache.scope
|
|
||||||
when :box
|
|
||||||
@env[:home_path].join('cache', @env[:machine].box.name)
|
|
||||||
when :machine
|
|
||||||
@env[:machine].data_dir.join('cache')
|
|
||||||
else
|
|
||||||
raise "Unknown cache scope: '#{@env[:machine].config.cache.scope}'"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -1,6 +1,6 @@
|
||||||
require_relative 'action/provision_ext'
|
require_relative 'provision_ext'
|
||||||
Vagrant::Action::Builtin::Provision.class_eval do
|
Vagrant::Action::Builtin::Provision.class_eval do
|
||||||
include VagrantPlugins::Cachier::Action::ProvisionExt
|
include VagrantPlugins::Cachier::ProvisionExt
|
||||||
end
|
end
|
||||||
|
|
||||||
# Add our custom translations to the load path
|
# Add our custom translations to the load path
|
||||||
|
|
68
lib/vagrant-cachier/provision_ext.rb
Normal file
68
lib/vagrant-cachier/provision_ext.rb
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
require_relative 'bucket'
|
||||||
|
|
||||||
|
module VagrantPlugins
|
||||||
|
module Cachier
|
||||||
|
module ProvisionExt
|
||||||
|
def self.included(base)
|
||||||
|
base.class_eval do
|
||||||
|
def cachier_debug(msg)
|
||||||
|
@logger.debug "[CACHIER] #{msg}"
|
||||||
|
end
|
||||||
|
|
||||||
|
alias :old_call :call
|
||||||
|
def call(env)
|
||||||
|
return old_call(env) unless env[:machine].config.cache.enabled?
|
||||||
|
|
||||||
|
@env = env
|
||||||
|
|
||||||
|
FileUtils.mkdir_p(cache_root.to_s) unless cache_root.exist?
|
||||||
|
|
||||||
|
nfs_flag = env[:machine].config.cache.enable_nfs
|
||||||
|
env[:machine].config.vm.synced_folder cache_root, '/tmp/vagrant-cache', id: "vagrant-cache", nfs: nfs_flag
|
||||||
|
|
||||||
|
env[:cache_dirs] = []
|
||||||
|
|
||||||
|
old_call(env)
|
||||||
|
|
||||||
|
configure_cache_buckets
|
||||||
|
end
|
||||||
|
|
||||||
|
alias :old_run_provisioner :run_provisioner
|
||||||
|
def run_provisioner(*args)
|
||||||
|
configure_cache_buckets
|
||||||
|
old_run_provisioner(*args)
|
||||||
|
end
|
||||||
|
|
||||||
|
def configure_cache_buckets
|
||||||
|
if @env[:machine].config.cache.auto_detect
|
||||||
|
Bucket.auto_detect(@env)
|
||||||
|
end
|
||||||
|
|
||||||
|
return unless @env[:machine].config.cache.buckets.any?
|
||||||
|
|
||||||
|
@env[:ui].info 'Configuring cache buckets...'
|
||||||
|
cache_config = @env[:machine].config.cache
|
||||||
|
cache_config.buckets.each do |bucket_name, configs|
|
||||||
|
cachier_debug "Installing #{bucket_name} with configs #{configs.inspect}"
|
||||||
|
Bucket.install(bucket_name, @env, configs)
|
||||||
|
end
|
||||||
|
|
||||||
|
data_file = @env[:machine].data_dir.join('cache_dirs')
|
||||||
|
data_file.open('w') { |f| f.print @env[:cache_dirs].uniq.join("\n") }
|
||||||
|
end
|
||||||
|
|
||||||
|
def cache_root
|
||||||
|
@cache_root ||= case @env[:machine].config.cache.scope
|
||||||
|
when :box
|
||||||
|
@env[:home_path].join('cache', @env[:machine].box.name)
|
||||||
|
when :machine
|
||||||
|
@env[:machine].data_dir.join('cache')
|
||||||
|
else
|
||||||
|
raise "Unknown cache scope: '#{@env[:machine].config.cache.scope}'"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue