Skip to content

Commit

Permalink
feat(influx): add json output flag for pkg commands that print tables
Browse files Browse the repository at this point in the history
  • Loading branch information
jsteenb2 committed Mar 27, 2020
1 parent 3764646 commit f0c0b82
Show file tree
Hide file tree
Showing 2 changed files with 64 additions and 14 deletions.
31 changes: 30 additions & 1 deletion cmd/influx/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ func (o genericCLIOpts) newCmd(use string, runE func(*cobra.Command, []string) e
}

func (o genericCLIOpts) writeJSON(v interface{}) error {
return json.NewEncoder(o.w).Encode(v)
return writeJSON(o.w, v)
}

func (o genericCLIOpts) newTabWriter() *internal.TabWriter {
Expand Down Expand Up @@ -441,12 +441,41 @@ func (f flagOpts) mustRegister(cmd *cobra.Command) {
cli.BindOptions(cmd, f)
}

func registerPrintOptions(cmd *cobra.Command, headersP, jsonOutP *bool) {
var opts flagOpts
if headersP != nil {
opts = append(opts, cli.Opt{
DestP: headersP,
Flag: "hide-headers",
EnvVar: "HIDE_HEADERS",
Desc: "Hide the table headers; defaults false",
Default: false,
})
}
if jsonOutP != nil {
opts = append(opts, cli.Opt{
DestP: jsonOutP,
Flag: "json",
EnvVar: "OUTPUT_JSON",
Desc: "Output data as json; defaults false",
Default: false,
})
}
opts.mustRegister(cmd)
}

func setViperOptions() {
viper.SetEnvPrefix("INFLUX")
viper.AutomaticEnv()
viper.SetEnvKeyReplacer(strings.NewReplacer("-", "_"))
}

func writeJSON(w io.Writer, v interface{}) error {
enc := json.NewEncoder(w)
enc.SetIndent("", "\t")
return enc.Encode(v)
}

func newBucketService() (influxdb.BucketService, error) {
if flags.local {
return newLocalKVService()
Expand Down
47 changes: 34 additions & 13 deletions cmd/influx/pkg.go
Original file line number Diff line number Diff line change
Expand Up @@ -97,10 +97,9 @@ func (b *cmdPkgBuilder) cmdPkgApply() *cobra.Command {

b.org.register(cmd, false)
b.registerPkgFileFlags(cmd)
b.registerPkgPrintOpts(cmd)
cmd.Flags().BoolVarP(&b.quiet, "quiet", "q", false, "Disable output printing")
cmd.Flags().StringVar(&b.applyOpts.force, "force", "", `TTY input, if package will have destructive changes, proceed if set "true"`)
cmd.Flags().BoolVarP(&b.disableColor, "disable-color", "c", false, "Disable color in output")
cmd.Flags().BoolVar(&b.disableTableBorders, "disable-table-borders", false, "Disable table borders")

b.applyOpts.secrets = []string{}
cmd.Flags().StringSliceVar(&b.applyOpts.secrets, "secret", nil, "Secrets to provide alongside the package; format should --secret=SECRET_KEY=SECRET_VALUE --secret=SECRET_KEY_2=SECRET_VALUE_2")
Expand Down Expand Up @@ -155,8 +154,8 @@ func (b *cmdPkgBuilder) pkgApplyRunEFn(cmd *cobra.Command, args []string) error
}
}

if !b.quiet {
b.printPkgDiff(diff)
if err := b.printPkgDiff(diff); err != nil {
return err
}

isForced, _ := strconv.ParseBool(b.applyOpts.force)
Expand All @@ -177,9 +176,7 @@ func (b *cmdPkgBuilder) pkgApplyRunEFn(cmd *cobra.Command, args []string) error
return err
}

if !b.quiet {
b.printPkgSummary(summary)
}
b.printPkgSummary(summary)

return nil
}
Expand Down Expand Up @@ -319,16 +316,14 @@ func (b *cmdPkgBuilder) cmdPkgSummary() *cobra.Command {
return err
}

b.printPkgSummary(pkg.Summary())
return nil
return b.printPkgSummary(pkg.Summary())
}

cmd := b.newCmd("summary", runE, false)
cmd.Short = "Summarize the provided package"

b.registerPkgFileFlags(cmd)
cmd.Flags().BoolVarP(&b.disableColor, "disable-color", "c", false, "Disable color in output")
cmd.Flags().BoolVar(&b.disableTableBorders, "disable-table-borders", false, "Disable table borders")
b.registerPkgPrintOpts(cmd)

return cmd
}
Expand Down Expand Up @@ -412,6 +407,12 @@ func (b *cmdPkgBuilder) stackInitRunEFn(cmd *cobra.Command, args []string) error
return nil
}

func (b *cmdPkgBuilder) registerPkgPrintOpts(cmd *cobra.Command) {
cmd.Flags().BoolVarP(&b.disableColor, "disable-color", "c", false, "Disable color in output")
cmd.Flags().BoolVar(&b.disableTableBorders, "disable-table-borders", false, "Disable table borders")
registerPrintOptions(cmd, nil, &b.json)
}

func (b *cmdPkgBuilder) registerPkgFileFlags(cmd *cobra.Command) {
cmd.Flags().StringSliceVarP(&b.files, "file", "f", nil, "Path to package file")
cmd.MarkFlagFilename("file", "yaml", "yml", "json", "jsonnet")
Expand Down Expand Up @@ -664,7 +665,15 @@ func newPkgerSVC() (pkger.SVC, influxdb.OrganizationService, error) {
return &pkger.HTTPRemoteService{Client: httpClient}, orgSvc, nil
}

func (b *cmdPkgBuilder) printPkgDiff(diff pkger.Diff) {
func (b *cmdPkgBuilder) printPkgDiff(diff pkger.Diff) error {
if b.quiet {
return nil
}

if b.json {
return b.writeJSON(diff)
}

red := color.New(color.FgRed).SprintFunc()
green := color.New(color.FgHiGreen, color.Bold).SprintFunc()

Expand Down Expand Up @@ -853,9 +862,19 @@ func (b *cmdPkgBuilder) printPkgDiff(diff pkger.Diff) {
}
})
}

return nil
}

func (b *cmdPkgBuilder) printPkgSummary(sum pkger.Summary) {
func (b *cmdPkgBuilder) printPkgSummary(sum pkger.Summary) error {
if b.quiet {
return nil
}

if b.json {
return b.writeJSON(sum)
}

tablePrintFn := b.tablePrinterGen()
if labels := sum.Labels; len(labels) > 0 {
headers := []string{"ID", "Name", "Description", "Color"}
Expand Down Expand Up @@ -997,6 +1016,8 @@ func (b *cmdPkgBuilder) printPkgSummary(sum pkger.Summary) {
return []string{secrets[i]}
})
}

return nil
}

func (b *cmdPkgBuilder) tablePrinterGen() func(table string, headers []string, count int, rowFn func(i int) []string) {
Expand Down

0 comments on commit f0c0b82

Please sign in to comment.