code-mancers/invoker

View on GitHub
lib/invoker/command_worker.rb

Summary

Maintainability
A
25 mins
Test Coverage
module Invoker
  class CommandWorker
    attr_accessor :command_label, :pipe_end, :pid, :color

    def initialize(command_label, pipe_end, pid, color)
      @command_label = command_label
      @pipe_end = pipe_end
      @pid = pid
      @color = color
    end

    # Copied verbatim from Eventmachine code
    def receive_data data
      (@buf ||= '') << data

      while @buf.slice!(/(.*?)\r?\n/)
        receive_line($1)
      end
    end

    def unbind
      Invoker::Logger.print(".")
    end

    # Print the lines received over the network
    def receive_line(line)
      tail_watchers = Invoker.tail_watchers[@command_label]
      color_line = "#{@command_label.colorize(color)} : #{line}"
      plain_line = "#{@command_label} : #{line}"
      if Invoker.nocolors?
        Invoker::Logger.puts plain_line
      else
        Invoker::Logger.puts color_line
      end
      if tail_watchers && !tail_watchers.empty?
        json_encoded_tail_response = tail_response(color_line)
        if json_encoded_tail_response
          tail_watchers.each { |tail_socket| send_data(tail_socket, json_encoded_tail_response) }
        end
      end
    end

    def to_h
      { command_label:  command_label, pid:  pid.to_s }
    end

    def send_data(socket, data)
      socket.write(data)
    rescue
      Invoker::Logger.puts "Removing #{@command_label} watcher #{socket} from list"
      Invoker.tail_watchers.remove(@command_label, socket)
    end

    private

    # Encode current line as json and send the response.
    def tail_response(line)
      tail_response = Invoker::IPC::Message::TailResponse.new(tail_line: line)
      tail_response.encoded_message
    rescue
      nil
    end
  end
end