class Farmstead::Transform::Service

Public Instance Methods

run() click to toggle source
# File lib/farmstead/pipeline/transform.rb, line 16
def run
  @consumer.subscribe("Forest")
  trap('TERM') { @consumer.stop }
  @consumer.each_message do |message|
    puts "Received: #{message.value}"
    # Run the load method of the module referenced by the message
    obj = JSON.parse(message.value)
    project_name = ENV["name"].capitalize
    module_name = obj["module_name"]
    my_module = Object.const_get "#{project_name}::#{module_name}"
    result = my_module::transform(obj["result"])
    puts result
    Farmstead::DB.insert_test(result)
    hash = {module_name: module_name, result: result}
    hash = hash.to_json
    @producer.produce(hash, topic: "Road")
    @producer.deliver_messages
    @consumer.mark_message_as_processed(message)
  end
end