Sha256: a721782a3f00245ea0ac00032253bac10d78e54b038908818864809a06cb2e78
Contents?: true
Size: 1.09 KB
Versions: 2
Compression:
Stored size: 1.09 KB
Contents
require_relative './ts_cell_codec' require_relative './operator' class Riak::Client::BeefcakeProtobuffsBackend def time_series_query_operator TimeSeriesQueryOperator.new(self) end class TimeSeriesQueryOperator < Operator def query(base, interpolations = { }) interpolator = TsInterpolation.new base: base interpolator.interpolations = pairs_for interpolations request = TsQueryReq.new query: interpolator result = backend.protocol do |p| p.write :TsQueryReq, request p.expect :TsQueryResp, TsQueryResp, empty_body_acceptable: true end return nil if :empty == result codec = TsCellCodec.new collection = Riak::TimeSeries::Collection. new(result.rows.map do |row| Riak::TimeSeries::Row.new codec.scalars_for row.cells end) collection.columns = result.columns collection end private def pairs_for(interpolations) interpolations.map do |key, value| RpbPair.new key: key.to_s, value: value.to_s end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
riak-client-2.3.1 | lib/riak/client/beefcake/time_series_query_operator.rb |
riak-client-2.3.0 | lib/riak/client/beefcake/time_series_query_operator.rb |