module EventSource module Postgres class Get class Last include EventSource::Get dependency :session, Session def self.build(session: nil) new.tap do |instance| instance.configure(session: session) end end def self.configure(receiver, attr_name: nil, session: nil) attr_name ||= :get instance = build(session: session) receiver.public_send "#{attr_name}=", instance end def configure(session: nil) Session.configure self, session: session end def self.call(stream_name, session: nil) instance = build(session: session) instance.(stream_name) end def call(stream_name) logger.trace { "Getting last event data (Stream Name: #{stream_name})" } record = get_record(stream_name) return nil if record.nil? event = convert(record) logger.info { "Finished getting event data (Stream Name: #{stream_name})" } logger.info(tags: [:data, :event_data]) { event.pretty_inspect } event end def get_record(stream_name) logger.trace { "Getting last record (Stream: #{stream_name})" } select_statement = SelectStatement.build(stream_name) records = session.execute(select_statement.sql) logger.debug { "Finished getting record (Stream: #{stream_name})" } return nil if records.ntuples == 0 records[0] end def convert(record) logger.trace { "Converting record to event data" } record['data'] = Deserialize.data(record['data']) record['metadata'] = Deserialize.metadata(record['metadata']) record['time'] = Time.utc_coerced(record['time']) event = EventData::Read.build(record) logger.debug { "Converted record to event data" } event end def __convert(records) logger.trace { "Converting records to event data (Records Count: #{records.ntuples})" } events = records.map do |record| record['data'] = Deserialize.data(record['data']) record['metadata'] = Deserialize.metadata(record['metadata']) record['time'] = Time.utc_coerced(record['time']) EventData::Read.build record break end logger.debug { "Converted records to event data (Event Data Count: #{events.length})" } events end module Deserialize def self.data(serialized_data) return nil if serialized_data.nil? Transform::Read.(serialized_data, EventData::Hash, :json) end def self.metadata(serialized_metadata) return nil if serialized_metadata.nil? Transform::Read.(serialized_metadata, EventData::Hash, :json) end end module Time def self.utc_coerced(local_time) Clock::UTC.coerce(local_time) end end end end end end