104 lines
2.7 KiB
Go
104 lines
2.7 KiB
Go
package query
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/influxdata/flux"
|
|
"github.com/influxdata/flux/execute"
|
|
"github.com/influxdata/flux/memory"
|
|
"github.com/influxdata/flux/plan"
|
|
"github.com/influxdata/influxdb/v2"
|
|
"github.com/influxdata/influxdb/v2/storage/reads/datatypes"
|
|
"github.com/influxdata/influxdb/v2/tsdb/cursors"
|
|
)
|
|
|
|
// StorageReader is an interface for reading tables from the storage subsystem.
|
|
type StorageReader interface {
|
|
ReadFilter(ctx context.Context, spec ReadFilterSpec, alloc *memory.Allocator) (TableIterator, error)
|
|
ReadGroup(ctx context.Context, spec ReadGroupSpec, alloc *memory.Allocator) (TableIterator, error)
|
|
|
|
ReadTagKeys(ctx context.Context, spec ReadTagKeysSpec, alloc *memory.Allocator) (TableIterator, error)
|
|
ReadTagValues(ctx context.Context, spec ReadTagValuesSpec, alloc *memory.Allocator) (TableIterator, error)
|
|
|
|
Close()
|
|
}
|
|
|
|
// WindowAggregateCapability describes what is supported by WindowAggregateReader.
|
|
type WindowAggregateCapability interface {
|
|
HaveMin() bool
|
|
HaveMax() bool
|
|
HaveMean() bool
|
|
HaveCount() bool
|
|
HaveSum() bool
|
|
}
|
|
|
|
// WindowAggregateReader implements the WindowAggregate capability.
|
|
type WindowAggregateReader interface {
|
|
// GetWindowAggregateCapability will get a detailed list of what the RPC call supports
|
|
// for window aggregate.
|
|
GetWindowAggregateCapability(ctx context.Context) WindowAggregateCapability
|
|
|
|
// ReadWindowAggregate will read a table using the WindowAggregate method.
|
|
ReadWindowAggregate(ctx context.Context, spec ReadWindowAggregateSpec, alloc *memory.Allocator) (TableIterator, error)
|
|
}
|
|
|
|
type ReadFilterSpec struct {
|
|
OrganizationID influxdb.ID
|
|
BucketID influxdb.ID
|
|
|
|
Bounds execute.Bounds
|
|
Predicate *datatypes.Predicate
|
|
}
|
|
|
|
type ReadGroupSpec struct {
|
|
ReadFilterSpec
|
|
|
|
GroupMode GroupMode
|
|
GroupKeys []string
|
|
|
|
AggregateMethod string
|
|
}
|
|
|
|
type ReadTagKeysSpec struct {
|
|
ReadFilterSpec
|
|
}
|
|
|
|
type ReadTagValuesSpec struct {
|
|
ReadFilterSpec
|
|
TagKey string
|
|
}
|
|
|
|
type ReadWindowAggregateSpec struct {
|
|
ReadFilterSpec
|
|
WindowEvery int64
|
|
Aggregates []plan.ProcedureKind
|
|
}
|
|
|
|
// TableIterator is a table iterator that also keeps track of cursor statistics from the storage engine.
|
|
type TableIterator interface {
|
|
flux.TableIterator
|
|
Statistics() cursors.CursorStats
|
|
}
|
|
|
|
type GroupMode int
|
|
|
|
const (
|
|
// GroupModeNone merges all series into a single group.
|
|
GroupModeNone GroupMode = iota
|
|
// GroupModeBy produces a table for each unique value of the specified GroupKeys.
|
|
GroupModeBy
|
|
)
|
|
|
|
// ToGroupMode accepts the group mode from Flux and produces the appropriate storage group mode.
|
|
func ToGroupMode(fluxMode flux.GroupMode) GroupMode {
|
|
switch fluxMode {
|
|
case flux.GroupModeNone:
|
|
return GroupModeNone
|
|
case flux.GroupModeBy:
|
|
return GroupModeBy
|
|
default:
|
|
panic(fmt.Sprint("unknown group mode: ", fluxMode))
|
|
}
|
|
}
|