#
#
# 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