vagrant/plugins/kernel_v2/config/trigger.rb

106 lines
3.1 KiB
Ruby
Raw Normal View History

2018-03-08 22:20:21 +00:00
require "vagrant"
require 'pry'
require File.expand_path("../vm_trigger", __FILE__)
2018-03-08 22:20:21 +00:00
module VagrantPlugins
module Kernel_V2
class TriggerConfig < Vagrant.plugin("2", :config)
2018-03-08 23:34:39 +00:00
2018-03-08 22:20:21 +00:00
def initialize
@logger = Log4r::Logger.new("vagrant::config::trigger")
# Internal State
@_before_triggers = [] # An array of VagrantConfigTrigger objectrs
@_after_triggers = [] # An array of VagrantConfigTrigger objectrs
2018-03-08 22:20:21 +00:00
end
2018-03-10 00:45:48 +00:00
# Reads in and parses Vagrant command whitelist and settings for a defined
# trigger
#
# @param [Symbol] command Vagrant command to create trigger on
2018-03-10 00:45:48 +00:00
# @param [Block] block The defined before block
def before(*command, &block)
blk = block
if !block_given? && command.last.is_a?(Hash)
# We were given a hash rather than a block,
# so the last element should be the "config block"
# and the rest are commands for the trigger
blk = command.pop
2018-03-10 00:45:48 +00:00
else
# No config block given at all, validation step should throw error?
end
command.each do |cmd|
trigger = VagrantConfigTrigger.new(cmd)
trigger.add_config(blk)
@_before_triggers << trigger
end
2018-03-08 22:20:21 +00:00
end
# Reads in and parses Vagrant command whitelist and settings for a defined
# trigger
#
# @param [Symbol] command Vagrant command to create trigger on
# @param [Block] block The defined before block
def after(*command, &block)
blk = block
if !block_given? && command.last.is_a?(Hash)
# We were given a hash rather than a block,
# so the last element should be the "config block"
# and the rest are commands for the trigger
blk = command.pop
2018-03-10 00:45:48 +00:00
else
# No config block given at all, validation step should throw error?
end
2018-03-08 22:20:21 +00:00
2018-03-10 00:45:48 +00:00
command.each do |cmd|
trigger = VagrantConfigTrigger.new(cmd)
trigger.add_config(blk)
@_after_triggers << trigger
2018-03-10 00:45:48 +00:00
end
end
#-------------------------------------------------------------------
# Internal methods, don't call these.
#-------------------------------------------------------------------
2018-03-10 00:45:48 +00:00
2018-03-08 22:20:21 +00:00
def finalize!
# read through configured settings blocks and set their values
# and then set up action hooks here?
# for some reason not all triggers are showing up here
#puts @_before_triggers if !@_before_triggers.empty?
#puts @_after_triggers if !@_after_triggers.empty?
if !@_before_triggers.empty?
binding.pry
end
2018-03-08 22:20:21 +00:00
end
2018-03-08 23:31:58 +00:00
# Validate Trigger settings
2018-03-08 22:20:21 +00:00
def validate(machine)
if !@_before_triggers.empty?
binding.pry
end
2018-03-09 21:06:26 +00:00
errors = _detected_errors
@_before_triggers.each do |bt|
errors << bt.validate(machine)
end
@_after_triggers.each do |at|
errors << at.validate(machine)
end
2018-03-09 21:06:26 +00:00
{"triggers" => errors}
2018-03-08 22:20:21 +00:00
end
# The String representation of this Trigger.
#
# @return [String]
def to_s
"Trigger"
end
end
end
end