Sha256: 9a854901bdea1a238fd7006ce244ae9749bdfb8a520cbce579d20c46aadf09c2

Contents?: true

Size: 1.93 KB

Versions: 3

Compression:

Stored size: 1.93 KB

Contents

$:.unshift(File.dirname(__FILE__)) unless
  $:.include?(File.dirname(__FILE__)) || $:.include?(File.expand_path(File.dirname(__FILE__)))

# = Description
# Provides a simple interface to polymorphically access to the spam protection 
# service of your choice.
# 
# = Usage
# I find it useful to first initialize Viking in a separate file during 
# framework initialization. Rails initializers, for instance, work great for 
# this. An example of such an initializer would be as follows:
# 
#   Viking.default_engie = 'defensio'
#   Viking.connect_options = { :api_key => '1234abc' }
# 
# From this point out, Viking should have everything it needs to access the 
# service of your choice. Merely call methods on your service of choice as 
# documented. For instance:
# 
#   Viking.mark_as_spam(:signaturs => "1234abc")
module Viking
  class Error < StandardError; end

  class << self
    attr_accessor :logger
    attr_accessor :default_engine
    attr_accessor :connect_options
    attr_writer   :default_instance

    def default_instance
      @default_instance ||= connect(default_engine, connect_options)
    end

    def enabled?
      !default_instance.nil?
    end

    def connect(engine, options)
      unless engine.nil? || engine.empty?
        require(engine)
        Viking.const_get(engine.to_s.capitalize).new(options)
      end
    end

    def verified?()               default_instance.verified?;              end
    def check_article(options={}) default_instance.check_article(options); end
    def check_comment(options={}) default_instance.check_comment(options); end
    def mark_as_spam(options={})  default_instance.mark_as_spam(options);  end
    def mark_as_ham(options={})   default_instance.mark_as_ham(options);   end
    def stats()                   default_instance.stats;                  end

    def mark_as_spam_or_ham(is_spam, options={})
      default_instance.mark_as_spam_or_ham(is_spam, options)
    end
  end
end

require 'base'

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
vikinggem-0.0.1 lib/viking/viking.rb
vikinggem-0.0.2 lib/viking/viking.rb
vikinggem-0.0.3 lib/viking/viking.rb