-
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathcli.go
70 lines (59 loc) · 1.85 KB
/
cli.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
package cli
import (
"fmt"
"io/ioutil"
"os"
"strings"
"github.com/arduino/arduino-cli/cli/errorcodes"
"github.com/arduino/arduino-cli/cli/feedback"
"github.com/arduino/iot-cloud-cli/cli/config"
"github.com/arduino/iot-cloud-cli/cli/device"
"github.com/arduino/iot-cloud-cli/cli/thing"
"github.com/sirupsen/logrus"
"github.com/spf13/cobra"
)
var cliFlags struct {
verbose bool
outputFormat string
}
func Execute() {
cli := &cobra.Command{
Use: "arduino-cloud-cli",
Short: "Arduino Cloud CLI.",
Long: "Arduino Cloud Command Line Interface (arduino-cloud-cli).",
PersistentPreRun: preRun,
}
cli.AddCommand(config.NewCommand())
cli.AddCommand(device.NewCommand())
cli.AddCommand(thing.NewCommand())
cli.PersistentFlags().BoolVarP(&cliFlags.verbose, "verbose", "v", false, "Print the logs on the standard output.")
cli.PersistentFlags().StringVar(&cliFlags.outputFormat, "format", "text", "The output format, can be {text|json}.")
if err := cli.Execute(); err != nil {
fmt.Fprintln(os.Stderr, err)
}
}
func parseFormatString(arg string) (feedback.OutputFormat, bool) {
f, found := map[string]feedback.OutputFormat{
"json": feedback.JSON,
"text": feedback.Text,
}[arg]
return f, found
}
func preRun(cmd *cobra.Command, args []string) {
logrus.SetOutput(ioutil.Discard)
// enable log only if verbose flag is passed
if cliFlags.verbose {
logrus.SetLevel(logrus.InfoLevel)
logrus.SetOutput(os.Stdout)
}
// normalize the format strings
cliFlags.outputFormat = strings.ToLower(cliFlags.outputFormat)
// check the right output format was passed
format, found := parseFormatString(cliFlags.outputFormat)
if !found {
feedback.Error("Invalid output format: " + cliFlags.outputFormat)
os.Exit(errorcodes.ErrBadCall)
}
// use the output format to configure the Feedback
feedback.SetFormat(format)
}