summaryrefslogtreecommitdiff
path: root/cmd/commandfuncs.go
diff options
context:
space:
mode:
authorMatthew Holt <mholt@users.noreply.github.com>2019-10-01 11:02:13 -0600
committerMatthew Holt <mholt@users.noreply.github.com>2019-10-01 11:02:13 -0600
commit2c3657bb8a37ce9c644dc1889223e37ca9988148 (patch)
treec3b749791a4c928c230d540803741e38fbee0b23 /cmd/commandfuncs.go
parent5b36424cf056cc2063c708f0b68ba7cd68d23ac8 (diff)
cmd: CLI improvements; add --validate to adapt command
Diffstat (limited to 'cmd/commandfuncs.go')
-rw-r--r--cmd/commandfuncs.go29
1 files changed, 26 insertions, 3 deletions
diff --git a/cmd/commandfuncs.go b/cmd/commandfuncs.go
index 715f064..5fba368 100644
--- a/cmd/commandfuncs.go
+++ b/cmd/commandfuncs.go
@@ -351,10 +351,11 @@ func cmdAdaptConfig(fl Flags) (int, error) {
adaptCmdInputFlag := fl.String("config")
adaptCmdAdapterFlag := fl.String("adapter")
adaptCmdPrettyFlag := fl.Bool("pretty")
+ adaptCmdValidateFlag := fl.Bool("validate")
if adaptCmdAdapterFlag == "" || adaptCmdInputFlag == "" {
return caddy.ExitCodeFailedStartup,
- fmt.Errorf("usage: caddy adapt --adapter <name> --input <file>")
+ fmt.Errorf("--adapter and --config flags are required")
}
cfgAdapter := caddyconfig.GetAdapter(adaptCmdAdapterFlag)
@@ -391,6 +392,19 @@ func cmdAdaptConfig(fl Flags) (int, error) {
// print result to stdout
fmt.Println(string(adaptedConfig))
+ // validate output if requested
+ if adaptCmdValidateFlag {
+ var cfg *caddy.Config
+ err = json.Unmarshal(adaptedConfig, &cfg)
+ if err != nil {
+ return caddy.ExitCodeFailedStartup, fmt.Errorf("decoding config: %v", err)
+ }
+ err = caddy.Validate(cfg)
+ if err != nil {
+ return caddy.ExitCodeFailedStartup, fmt.Errorf("validation: %v", err)
+ }
+ }
+
return caddy.ExitCodeSuccess, nil
}
@@ -457,7 +471,8 @@ usage:
commands:
`
for _, cmd := range commands {
- s += fmt.Sprintf(" %-15s %s\n", cmd.Name, cmd.Short)
+ short := strings.TrimSuffix(cmd.Short, ".")
+ s += fmt.Sprintf(" %-15s %s\n", cmd.Name, short)
}
s += "\nUse 'caddy help <command>' for more information about a command.\n"
@@ -475,8 +490,16 @@ commands:
return caddy.ExitCodeFailedStartup, fmt.Errorf("unknown command: %s", args[0])
}
+ helpText := strings.TrimSpace(subcommand.Long)
+ if helpText == "" {
+ helpText = subcommand.Short
+ if !strings.HasSuffix(helpText, ".") {
+ helpText += "."
+ }
+ }
+
result := fmt.Sprintf("%s\n\nusage:\n caddy %s %s\n",
- strings.TrimSpace(subcommand.Long),
+ helpText,
subcommand.Name,
strings.TrimSpace(subcommand.Usage),
)