Sha256: 8b6ab1f7682fd8d884c6e5afd6feab699720a9c4845e2cd6aaf89e2a9892534a

Contents?: true

Size: 1.95 KB

Versions: 20

Compression:

Stored size: 1.95 KB

Contents

module Oxidized
class HookManager
  class << self
    def from_config cfg
      mgr = new
      cfg.hooks.each do |name,h_cfg|
        h_cfg.events.each do |event|
          mgr.register event.to_sym, name, h_cfg.type, h_cfg
        end
      end
      mgr
    end
  end

  # HookContext is passed to each hook. It can contain anything related to the
  # event in question. At least it contains the event name
  class HookContext < OpenStruct; end

  # RegisteredHook is a container for a Hook instance
  class RegisteredHook < Struct.new(:name, :hook); end

  Events = [
    :node_success,
    :node_fail,
    :post_store,
  ]
  attr_reader :registered_hooks

  def initialize
    @registered_hooks = Hash.new {|h,k| h[k] = []}
  end

  def register event, name, hook_type, cfg
    unless Events.include? event
      raise ArgumentError,
        "unknown event #{event}, available: #{Events.join ','}"
    end

    Oxidized.mgr.add_hook hook_type
    begin
      hook = Oxidized.mgr.hook.fetch(hook_type).new
    rescue KeyError
      raise KeyError, "cannot find hook #{hook_type.inspect}"
    end

    hook.cfg = cfg

    @registered_hooks[event] << RegisteredHook.new(name, hook)
    Oxidized.logger.debug "Hook #{name.inspect} registered #{hook.class} for event #{event.inspect}"
  end

  def handle event, ctx_params={}
    ctx = HookContext.new ctx_params
    ctx.event = event

    @registered_hooks[event].each do |r_hook|
      begin
        r_hook.hook.run_hook ctx
      rescue => e
        Oxidized.logger.error "Hook #{r_hook.name} (#{r_hook.hook}) failed " +
                  "(#{e.inspect}) for event #{event.inspect}"
      end
    end
  end
end

# Hook abstract base class
class Hook
  attr_reader :cfg

  def initialize
  end

  def cfg=(cfg)
    @cfg = cfg
    validate_cfg! if self.respond_to? :validate_cfg!
  end

  def run_hook ctx
    raise NotImplementedError
  end

  def log(msg, level=:info)
    Oxidized.logger.send(level, "#{self.class.name}: #{msg}")
  end

end
end

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
oxidized-0.20.0 lib/oxidized/hook.rb
oxidized-0.19.0 lib/oxidized/hook.rb
oxidized-0.18.0 lib/oxidized/hook.rb
oxidized-0.17.0 lib/oxidized/hook.rb
oxidized-0.16.3 lib/oxidized/hook.rb
oxidized-0.16.2 lib/oxidized/hook.rb
oxidized-0.16.1 lib/oxidized/hook.rb
oxidized-0.16.0 lib/oxidized/hook.rb
oxidized-0.15.0 lib/oxidized/hook.rb
oxidized-0.14.3 lib/oxidized/hook.rb
oxidized-0.14.2 lib/oxidized/hook.rb
oxidized-0.14.1 lib/oxidized/hook.rb
oxidized-0.14.0 lib/oxidized/hook.rb
oxidized-0.13.1 lib/oxidized/hook.rb
oxidized-0.13.0 lib/oxidized/hook.rb
oxidized-0.12.2 lib/oxidized/hook.rb
oxidized-0.12.1 lib/oxidized/hook.rb
oxidized-0.12.0 lib/oxidized/hook.rb
oxidized-0.11.0 lib/oxidized/hook.rb
oxidized-0.10.0 lib/oxidized/hook.rb