Sha256: 30955e13bc6486dc04884321213dc09a1e25ac1ebc08206fe9dca592d3ee35ec
Contents?: true
Size: 1.96 KB
Versions: 2
Compression:
Stored size: 1.96 KB
Contents
$: << File.dirname(__FILE__) require 'aws-sdk' require 'json' require_relative 'env' require 'alephant/models/logger' require 'alephant/models/queue' require 'alephant/models/cache' require 'alephant/models/renderer' require 'alephant/models/sequencer' require 'alephant/errors' require 'alephant/views' module Alephant class Alephant attr_reader :sequencer, :queue, :cache, :renderer VALID_OPTS = [ :s3_bucket_id, :s3_object_path, :s3_object_id, :table_name, :sqs_queue_id, :view_id, :view_path, :sequential_proc, :set_last_seen_proc ] def initialize(opts = {}, logger = nil) set_logger(logger) set_opts(opts) @logger = ::Alephant.logger @sequencer = Sequencer.new( { :table_name => @table_name }, @sqs_queue_id ) @queue = Queue.new(@sqs_queue_id) @cache = Cache.new(@s3_bucket_id, @s3_object_path) @renderer = Renderer.new(@view_id, @view_path) end def set_logger(logger) ::Alephant.logger = logger end def parse(msg) JSON.parse(msg, :symbolize_names => true) end def write(data) @cache.put( @s3_object_id, @renderer.render(data) ) end def receive(msg) data = parse(msg.body) @logger.info("Alephant.receive: with id #{msg.id} and body digest: #{msg.md5}") if @sequencer.sequential?(data, &@sequential_proc) write data @sequencer.set_last_seen(data, &@set_last_seen_proc) else @logger.warn("Alephant.receive: out of sequence message received #{msg.id} (discarded)") end end def run! Thread.new do @queue.poll { |msg| receive(msg) } end end private def set_opts(opts) VALID_OPTS.each do | k | v = opts.has_key?(k) ? opts[k] : nil singleton_class.class_eval do attr_accessor k end send("#{k}=", v) end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
alephant-0.0.8.1-java | lib/alephant.rb |
alephant-0.0.8-java | lib/alephant.rb |