feat(cmd/influx/query): add --file option #17356

pull/17595/head
Pavel Zavora 2020-04-03 07:31:10 +02:00
parent 21d2bf5dc6
commit 3449f23733
1 changed files with 44 additions and 7 deletions

View File

@ -2,30 +2,67 @@ package main
import (
"fmt"
"io/ioutil"
"os"
"strings"
"github.com/influxdata/flux"
"github.com/influxdata/flux/repl"
_ "github.com/influxdata/flux/stdlib"
_ "github.com/influxdata/influxdb/query/stdlib"
"github.com/spf13/cobra"
)
var queryFlags struct {
org organization
org organization
file string
}
func cmdQuery(f *globalFlags, opts genericCLIOpts) *cobra.Command {
cmd := opts.newCmd("query [query literal or @/path/to/query.flux]", fluxQueryF, true)
cmd := opts.newCmd("query [query literal or -f /path/to/query.flux]", fluxQueryF, true)
cmd.Short = "Execute a Flux query"
cmd.Long = `Execute a literal Flux query provided as a string,
or execute a literal Flux query contained in a file by specifying the file prefixed with an @ sign.`
cmd.Args = cobra.ExactArgs(1)
cmd.Long = `Execute a literal Flux query provided as a string argument or
in a file using the -f flag or via stdin`
cmd.Args = cobra.MaximumNArgs(1)
queryFlags.org.register(cmd, true)
cmd.Flags().StringVarP(&queryFlags.file, "file", "f", "", "The path to the Flux query file")
return cmd
}
// readFluxQuery returns first argument, file contents or stdin
func readFluxQuery(args []string, file string) (string, error) {
// backward compatibility
if len(args) > 0 {
if strings.HasPrefix(args[0], "@") {
file = args[0][1:]
args = args[:0]
} else if args[0] == "-" {
file = ""
args = args[:0]
}
}
var query string
switch {
case len(args) > 0:
query = args[0]
case len(file) > 0:
content, err := ioutil.ReadFile(file)
if err != nil {
return "", err
}
query = string(content)
default:
content, err := ioutil.ReadAll(os.Stdin)
if err != nil {
return "", err
}
query = string(content)
}
return query, nil
}
func fluxQueryF(cmd *cobra.Command, args []string) error {
if flags.local {
return fmt.Errorf("local flag not supported for query command")
@ -35,7 +72,7 @@ func fluxQueryF(cmd *cobra.Command, args []string) error {
return err
}
q, err := repl.LoadQuery(args[0])
q, err := readFluxQuery(args, queryFlags.file)
if err != nil {
return fmt.Errorf("failed to load query: %v", err)
}