influxdb/cmd/influxd/launcher/print_config.go

92 lines
2.4 KiB
Go

package launcher
import (
"fmt"
"io"
"github.com/influxdata/influxdb/v2/kit/cli"
"github.com/spf13/cobra"
"github.com/spf13/viper"
"gopkg.in/yaml.v3"
)
func NewInfluxdPrintConfigCommand(v *viper.Viper, influxdOpts []cli.Opt) (*cobra.Command, error) {
var keyToPrint string
printOpts := make([]cli.Opt, len(influxdOpts)+1)
printOpts[0] = cli.Opt{
DestP: &keyToPrint,
Flag: "key-name",
Desc: "config key name; if set, only the resolved value of that key will be printed",
}
for i, opt := range influxdOpts {
printOpts[i+1] = cli.Opt{
DestP: opt.DestP,
Flag: opt.Flag,
Hidden: true,
}
}
cmd := &cobra.Command{
Use: "print-config",
Short: "Print the full influxd config resolved from the current environment",
Deprecated: "use the influx-cli command server-config to display the configuration values from the running server",
Long: `
Print config (in YAML) that the influxd server would use if run with the current flags/env vars/config file.
The order of precedence for config options are as follows (1 highest, 3 lowest):
1. flags
2. env vars
3. config file
A config file can be provided via the INFLUXD_CONFIG_PATH env var. If a file is
not provided via an env var, influxd will look in the current directory for a
config.{json|toml|yaml|yml} file. If one does not exist, then it will continue unchanged.
See 'influxd -h' for the full list of config options supported by the server.
`,
RunE: func(cmd *cobra.Command, _ []string) error {
var err error
if keyToPrint == "" {
err = printAllConfigRunE(printOpts, cmd.OutOrStdout())
} else {
err = printOneConfigRunE(printOpts, keyToPrint, cmd.OutOrStdout())
}
if err != nil {
return fmt.Errorf("failed to print config: %w", err)
}
return nil
},
Args: cobra.NoArgs,
}
if err := cli.BindOptions(v, cmd, printOpts); err != nil {
return nil, err
}
return cmd, nil
}
func printAllConfigRunE(configOpts []cli.Opt, out io.Writer) error {
configMap := make(map[string]interface{}, len(configOpts))
for _, o := range configOpts {
configMap[o.Flag] = o.DestP
}
return yaml.NewEncoder(out).Encode(configMap)
}
func printOneConfigRunE(configOpts []cli.Opt, key string, out io.Writer) error {
for _, o := range configOpts {
if o.Flag != key {
continue
}
return yaml.NewEncoder(out).Encode(o.DestP)
}
return fmt.Errorf("key %q not found in config", key)
}