2019-01-08 00:37:16 +00:00
|
|
|
package influxdb
|
2018-07-31 22:50:02 +00:00
|
|
|
|
2020-03-05 20:36:58 +00:00
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
|
|
|
"github.com/influxdata/flux/ast"
|
2020-03-09 18:30:43 +00:00
|
|
|
"github.com/influxdata/flux/complete"
|
2020-03-05 20:36:58 +00:00
|
|
|
"github.com/influxdata/flux/interpreter"
|
|
|
|
"github.com/influxdata/flux/values"
|
|
|
|
)
|
2020-03-05 16:32:17 +00:00
|
|
|
|
2018-07-31 22:50:02 +00:00
|
|
|
// TODO(desa): These files are possibly a temporary. This is needed
|
|
|
|
// as a part of the source work that is being done.
|
2018-08-09 19:37:23 +00:00
|
|
|
// See https://github.com/influxdata/platform/issues/594 for more info.
|
2018-07-31 22:50:02 +00:00
|
|
|
|
|
|
|
// SourceQuery is a query for a source.
|
|
|
|
type SourceQuery struct {
|
|
|
|
Query string `json:"query"`
|
|
|
|
Type string `json:"type"`
|
|
|
|
}
|
2020-03-05 16:32:17 +00:00
|
|
|
|
|
|
|
// FluxLanguageService is a service for interacting with flux code.
|
|
|
|
type FluxLanguageService interface {
|
|
|
|
// 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.
|
|
|
|
Parse(source string) (*ast.Package, error)
|
2020-03-05 20:36:58 +00:00
|
|
|
|
|
|
|
// EvalAST will evaluate and run an AST.
|
|
|
|
EvalAST(ctx context.Context, astPkg *ast.Package) ([]interpreter.SideEffect, values.Scope, error)
|
2020-03-09 18:30:43 +00:00
|
|
|
|
|
|
|
// Completer will return a flux completer.
|
|
|
|
Completer() complete.Completer
|
2020-03-05 16:32:17 +00:00
|
|
|
}
|