Class: VagrantPlugins::Lifecycle::MiddleWare
- Inherits:
-
Object
- Object
- VagrantPlugins::Lifecycle::MiddleWare
- Defined in:
- lib/vagrant-lifecycle/middleware.rb
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app, env) ⇒ MiddleWare
constructor
A new instance of MiddleWare.
Constructor Details
#initialize(app, env) ⇒ MiddleWare
Returns a new instance of MiddleWare.
4 5 6 7 8 9 |
# File 'lib/vagrant-lifecycle/middleware.rb', line 4 def initialize(app, env) @app = app klass = self.class.name.downcase.split('::').last @logger = Log4r::Logger.new("vagrant::lifecycle::#{klass}") end |
Instance Method Details
#call(env) ⇒ Object
11 12 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 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
# File 'lib/vagrant-lifecycle/middleware.rb', line 11 def call(env) event = env[:lifecycle_event] || env[:machine].config.lifecycle.default_event || nil if event.nil? @app.call(env) else chef_provisioners = env[:machine].config.vm.provisioners.select do |provisioner| # Vagrant 1.7 changes provisioner.name to provisioner.type if provisioner.respond_to? :type provisioner.type.to_sym == :chef_solo || provisioner.type.to_sym == :chef_client || provisioner.type.to_sym == :chef_zero else provisioner.name.to_sym == :chef_solo || provisioner.name.to_sym == :chef_client || provisioner.name.to_sym == :chef_zero end end # @type [Hash] lifecycle_events = env[:machine].config.lifecycle.events if lifecycle_events.key?(event) || lifecycle_events.key?(event.to_sym) || lifecycle_events.key?(event.to_s) # @type [lambda] event_lambda = lifecycle_events[event] || lifecycle_events[event.to_sym] || lifecycle_events[event.to_s] chef_provisioners.each do |chef| begin new_run_list = event_lambda.call(chef.config.run_list || [], env) @logger.debug "Setting run_list = #{new_run_list.inspect}" if new_run_list.kind_of?(Array) chef.config.run_list = new_run_list else env[:ui].error "Could not evaluate proper run list for the lifecycle event #{event}!" env[:interrupted] = true end rescue Exception => e env[:ui].error "Failed while evaluating run list for the event #{event} with error: #{e}" env[:interrupted] = true end end else env[:ui].error "Lifecycle event #{event} not configured!" env[:interrupted] = true end @app.call(env) end end |