module MoSQL class Tailer < Mongoriver::AbstractPersistentTailer def self.create_table(db, tablename) db.create_table?(tablename) do column :service, 'TEXT' column :timestamp, 'INTEGER' primary_key [:service] end db[tablename.to_sym] end def initialize(backends, type, table, opts) super(backends, type, opts) @table = table @service = opts[:service] || "mosql" end def read_timestamp row = @table.where(:service => @service).select([:timestamp]).first if row BSON::Timestamp.new(row[:timestamp], 0) else BSON::Timestamp.new(0, 0) end end def write_timestamp(ts) begin @table.insert({:service => @service, :timestamp => ts.seconds}) rescue Sequel::DatabaseError => e raise unless e.message =~ /duplicate key value violates unique constraint/ @table.where(:service => @service).update(:timestamp => ts.seconds) end end end end