# # # Base class for custodian notifiers. # # Each subclass will register themselves, via the call to 'register_alert_type'. # # This class is a factory that will return the correct derived class. # # module Custodian class AlertFactory # # The target for the alert. # # The meaning of the target is notifier-specific. # # In the case of the smtp-notifier the target is the # email address to notify, for example. # attr_reader :target # # The global configuration settings object. # attr_reader :settings # # The subclasses we have. # @@subclasses = { } # # Create an notifier object, based upon name given to us. # # The "obj" here is the test-case that will be generating the # raise/clear event. # def self.create( alert_type, obj ) raise ArgumentError, 'The type of notifier to create cannot be nil' if alert_type.nil? raise ArgumentError, 'The type of notifier to create must be a string' unless alert_type.kind_of? String c = @@subclasses[alert_type] if c c.new( obj ) else raise ArgumentError, "Bad alert type: '#{alert_type}'" end end # # Register a new type of notifier - this must be called by our derived classes # def self.register_alert_type name @@subclasses[name] = self end # # Return the notifiers we know about. # # i.e. Derived classes that have registered themselves. # def self.known_alerters @@subclasses end # # Get the friendly-type of derived-classes. # def get_type @@subclasses.each do |name,value| if ( value == self.class ) return name end end nil end # # Set the target for this alert. # def set_target( target ) @target = target end # # Store a reference to the settings # def set_settings( obj ) @settings = obj end # # Raise an alert. # def raise puts 'NOP' end # # Clear an alert. # def clear puts 'NOP' end end end