Sha256: bca275ccd6354ed8adff9460822d1594d9da954d3e8e846d0516f4245d1765a8

Contents?: true

Size: 1.97 KB

Versions: 12

Compression:

Stored size: 1.97 KB

Contents

require 'protobuf/rpc/connectors/base'

module Protobuf
  module Rpc
    module Connectors
      class Socket < Base
        include Protobuf::Rpc::Connectors::Common
        include Protobuf::Logging

        def send_request
          timeout_wrap do
            setup_connection
            connect_to_rpc_server
            post_init
            read_response
          end
        end

        def log_signature
          @_log_signature ||= "[client-#{self.class}]"
        end

        private

        def close_connection
          @socket.close
          logger.debug { sign_message('Connector closed')  }
        end

        def connect_to_rpc_server
          @socket ||= TCPSocket.new(options[:host], options[:port])
          logger.debug { sign_message("Connection established #{options[:host]}:#{options[:port]}") }
        end

        # Method to determine error state, must be used with Connector api
        def error?
          return true if @error
          logger.debug { sign_message("Error state : #{@socket.closed?}")  }
          @socket.closed?
        end

        def read_data
          size_io = StringIO.new

          until (size_reader = @socket.getc) == "-"
            size_io << size_reader
          end
          str_size_io = size_io.string

          "#{str_size_io}-#{@socket.read(str_size_io.to_i)}"
        end

        def read_response
          logger.debug { sign_message("error? is #{error?}") }
          return if error?
          response_buffer = ::Protobuf::Rpc::Buffer.new(:read)
          response_buffer << read_data
          @response_data = response_buffer.data
          parse_response if response_buffer.flushed?
        end

        def send_data
          return if error?
          request_buffer = ::Protobuf::Rpc::Buffer.new(:write)
          request_buffer.set_data(@request_data)
          @socket.write(request_buffer.write)
          @socket.flush
          logger.debug { sign_message("write closed") }
        end
      end
    end
  end
end

Version data entries

12 entries across 12 versions & 2 rubygems

Version Path
protobuf-3.5.4 lib/protobuf/rpc/connectors/socket.rb
protobuf-3.5.3 lib/protobuf/rpc/connectors/socket.rb
protobuf-3.5.2 lib/protobuf/rpc/connectors/socket.rb
protobuf-3.5.1 lib/protobuf/rpc/connectors/socket.rb
prepor-protobuf-3.5.1 lib/protobuf/rpc/connectors/socket.rb
prepor-protobuf-3.5.0 lib/protobuf/rpc/connectors/socket.rb
protobuf-3.5.0 lib/protobuf/rpc/connectors/socket.rb
protobuf-3.4.4 lib/protobuf/rpc/connectors/socket.rb
protobuf-3.4.3 lib/protobuf/rpc/connectors/socket.rb
protobuf-3.4.2 lib/protobuf/rpc/connectors/socket.rb
protobuf-3.4.1 lib/protobuf/rpc/connectors/socket.rb
protobuf-3.4.0 lib/protobuf/rpc/connectors/socket.rb