Sha256: aa0be107da59912f69a043019cd9e5db2ee19a211606d52ce7bda10469d07016

Contents?: true

Size: 1.17 KB

Versions: 5

Compression:

Stored size: 1.17 KB

Contents

require_relative './ts_cell_codec'
require_relative './operator'

class Riak::Client::BeefcakeProtobuffsBackend
  def time_series_list_operator(convert_timestamp)
    TimeSeriesListOperator.new(self, convert_timestamp)
  end

  class TimeSeriesListOperator < Operator
    def initialize(backend, convert_timestamp)
      super(backend)
      @convert_timestamp = convert_timestamp
    end

    def list(table_name, block, options = {  })
      request = TsListKeysReq.new options.merge(table: table_name)

      return streaming_list_keys(request, &block) unless block.nil?

      Riak::TimeSeries::Collection.new.tap do |key_buffer|
        streaming_list_keys(request) do |key_row|
          key_buffer << key_row
        end
      end
    end

    private

    def streaming_list_keys(request)
      backend.protocol do |p|
        p.write :TsListKeysReq, request

        codec = TsCellCodec.new(@convert_timestamp)

        while resp = p.expect(:TsListKeysResp, TsListKeysResp)
          break if resp.done
          resp.keys.each do |row|
            key_fields = codec.scalars_for row.cells
            yield key_fields
          end
        end
      end

      true
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
riak-client-2.6.0 lib/riak/client/beefcake/time_series_list_operator.rb
riak-client-2.5.0 lib/riak/client/beefcake/time_series_list_operator.rb
riak-client-2.4.1 lib/riak/client/beefcake/time_series_list_operator.rb
riak-client-2.4.0 lib/riak/client/beefcake/time_series_list_operator.rb
riak-client-2.4.0.pre1 lib/riak/client/beefcake/time_series_list_operator.rb