2018-09-11 22:56:51 +00:00
|
|
|
package query
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"io"
|
|
|
|
|
|
|
|
"github.com/influxdata/flux"
|
2020-03-05 20:36:58 +00:00
|
|
|
"github.com/influxdata/flux/ast"
|
|
|
|
"github.com/influxdata/flux/interpreter"
|
|
|
|
"github.com/influxdata/flux/values"
|
2020-04-03 17:39:20 +00:00
|
|
|
"github.com/influxdata/influxdb/v2/kit/check"
|
2021-04-07 18:42:55 +00:00
|
|
|
"github.com/influxdata/influxdb/v2/kit/platform/errors"
|
|
|
|
"github.com/influxdata/influxdb/v2/query/fluxlang"
|
2018-09-11 22:56:51 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// QueryService represents a type capable of performing queries.
|
|
|
|
type QueryService interface {
|
2019-03-26 03:05:44 +00:00
|
|
|
check.Checker
|
|
|
|
|
2018-09-11 22:56:51 +00:00
|
|
|
// Query submits a query for execution returning a results iterator.
|
|
|
|
// Cancel must be called on any returned results to free resources.
|
|
|
|
Query(ctx context.Context, req *Request) (flux.ResultIterator, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
// AsyncQueryService represents a service for performing queries where the results are delivered asynchronously.
|
|
|
|
type AsyncQueryService interface {
|
|
|
|
// Query submits a query for execution returning immediately.
|
|
|
|
// Done must be called on any returned Query objects.
|
|
|
|
Query(ctx context.Context, req *Request) (flux.Query, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ProxyQueryService performs queries and encodes the result into a writer.
|
|
|
|
// The results are opaque to a ProxyQueryService.
|
|
|
|
type ProxyQueryService interface {
|
2019-03-26 03:05:44 +00:00
|
|
|
check.Checker
|
|
|
|
|
2018-09-11 22:56:51 +00:00
|
|
|
// Query performs the requested query and encodes the results into w.
|
|
|
|
// The number of bytes written to w is returned __independent__ of any error.
|
2019-03-07 15:32:13 +00:00
|
|
|
Query(ctx context.Context, w io.Writer, req *ProxyRequest) (flux.Statistics, error)
|
2018-09-11 22:56:51 +00:00
|
|
|
}
|
2020-03-05 20:36:58 +00:00
|
|
|
|
|
|
|
// Parse will take flux source code and produce a package.
|
|
|
|
// If there are errors when parsing, the first error is returned.
|
|
|
|
// An ast.Package may be returned when a parsing error occurs,
|
|
|
|
// but it may be null if parsing didn't even occur.
|
|
|
|
//
|
|
|
|
// This will return an error if the FluxLanguageService is nil.
|
2021-04-07 18:42:55 +00:00
|
|
|
func Parse(lang fluxlang.FluxLanguageService, source string) (*ast.Package, error) {
|
2020-03-05 20:36:58 +00:00
|
|
|
if lang == nil {
|
2021-03-30 18:10:02 +00:00
|
|
|
return nil, &errors.Error{
|
|
|
|
Code: errors.EInternal,
|
2020-03-05 20:36:58 +00:00
|
|
|
Msg: "flux is not configured; cannot parse",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return lang.Parse(source)
|
|
|
|
}
|
|
|
|
|
|
|
|
// EvalAST will evaluate and run an AST.
|
|
|
|
//
|
|
|
|
// This will return an error if the FluxLanguageService is nil.
|
2021-04-07 18:42:55 +00:00
|
|
|
func EvalAST(ctx context.Context, lang fluxlang.FluxLanguageService, astPkg *ast.Package) ([]interpreter.SideEffect, values.Scope, error) {
|
2020-03-05 20:36:58 +00:00
|
|
|
if lang == nil {
|
2021-03-30 18:10:02 +00:00
|
|
|
return nil, nil, &errors.Error{
|
|
|
|
Code: errors.EInternal,
|
2020-03-05 20:36:58 +00:00
|
|
|
Msg: "flux is not configured; cannot evaluate",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return lang.EvalAST(ctx, astPkg)
|
|
|
|
}
|