Sha256: ca146f3f376e249bc45ea086d78302a33dacc4955fe63df246878260e6b99774
Contents?: true
Size: 1.78 KB
Versions: 5
Compression:
Stored size: 1.78 KB
Contents
module MCollective module Data class Base attr_reader :name, :result, :ddl, :timeout # Register plugins that inherits base def self.inherited(klass) type = klass.to_s.split("::").last.downcase PluginManager << {:type => type, :class => klass.to_s, :single_instance => false} super end def initialize @name = self.class.to_s.split("::").last.downcase @ddl = DDL.new(@name, :data) @result = Result.new(@ddl.dataquery_interface[:output]) @timeout = @ddl.meta[:timeout] || 1 startup_hook end def lookup(what) ddl_validate(what) Log.debug("Doing data query %s for '%s'" % [@name, what]) Timeout.timeout(@timeout) do query_data(what) end @result rescue Timeout::Error # Timeout::Error is a inherited from Interrupt which seems a really # strange choice, making it an equivelant of ^C and such. Catch it # and raise something less critical that will not the runner to just # give up the ghost msg = "Data plugin %s timed out on query '%s'" % [@name, what] Log.error(msg) raise MsgTTLExpired, msg end def self.query(&block) module_eval { define_method("query_data", &block) } end def ddl_validate(what) Data.ddl_validate(@ddl, what) end # activate_when do # file.exist?("/usr/bin/puppet") # end def self.activate_when(&block) (class << self; self; end).instance_eval do define_method("activate?", &block) end end # Always be active unless a specific block is given with activate_when def self.activate? true end def startup_hook; end end end end
Version data entries
5 entries across 5 versions & 1 rubygems