From 6712fa580bac0e5aec1b4236be98a621fefab4d5 Mon Sep 17 00:00:00 2001 From: 1138-4EB <1138-4EB@users.noreply.github.com> Date: Sun, 6 Jan 2019 22:34:56 +0100 Subject: [PATCH] enable version subcmd and --version flag for root cmd and all subcmds Former-commit-id: a9e681d47d47f9f09a22d8479705f62672f509b7 [formerly b7d17db57156675b06897bc289fe616628a47abb] [formerly e06d3b13b547356fb928288b09aaaaf1a60b8950 [formerly b4708348c680385d1d89f14bea7c7a0a883c6bf8]] Former-commit-id: 43b18221e14269bada106e867b666f67a692c992 [formerly bee15f87fc2ecf5e8b4a0d74f41bde7617aef12a] Former-commit-id: 733aaa6f3d5e3fc80dbb65ccc028d9f6ff6f73b7 --- cmd/cmds.go | 9 +++++---- cmd/config.go | 9 +++++---- cmd/hash.go | 9 +++++---- cmd/root.go | 13 +++++++++---- cmd/rules.go | 5 +++-- cmd/upgrade.go | 5 +++-- cmd/users.go | 9 +++++---- cmd/version.go | 20 ++++++++++++++++---- 8 files changed, 51 insertions(+), 28 deletions(-) diff --git a/cmd/cmds.go b/cmd/cmds.go index cf951995..81613d02 100644 --- a/cmd/cmds.go +++ b/cmd/cmds.go @@ -11,10 +11,11 @@ func init() { } var cmdsCmd = &cobra.Command{ - Use: "cmds", - Short: "Command runner management utility", - Long: `Command runner management utility.`, - Args: cobra.NoArgs, + Use: "cmds", + Version: rootCmd.Version, + Short: "Command runner management utility", + Long: `Command runner management utility.`, + Args: cobra.NoArgs, } func printEvents(m map[string][]string) { diff --git a/cmd/config.go b/cmd/config.go index db97cf10..755b7139 100644 --- a/cmd/config.go +++ b/cmd/config.go @@ -20,10 +20,11 @@ func init() { } var configCmd = &cobra.Command{ - Use: "config", - Short: "Configuration management utility", - Long: `Configuration management utility.`, - Args: cobra.NoArgs, + Use: "config", + Version: rootCmd.Version, + Short: "Configuration management utility", + Long: `Configuration management utility.`, + Args: cobra.NoArgs, } func addConfigFlags(flags *pflag.FlagSet) { diff --git a/cmd/hash.go b/cmd/hash.go index e92203e4..b85144aa 100644 --- a/cmd/hash.go +++ b/cmd/hash.go @@ -12,10 +12,11 @@ func init() { } var hashCmd = &cobra.Command{ - Use: "hash ", - Short: "Hashes a password", - Long: `Hashes a password using bcrypt algorithm.`, - Args: cobra.ExactArgs(1), + Use: "hash ", + Version: rootCmd.Version, + Short: "Hashes a password", + Long: `Hashes a password using bcrypt algorithm.`, + Args: cobra.ExactArgs(1), Run: func(cmd *cobra.Command, args []string) { pwd, err := users.HashPwd(args[0]) checkErr(err) diff --git a/cmd/root.go b/cmd/root.go index b662e2a2..7e6915cb 100644 --- a/cmd/root.go +++ b/cmd/root.go @@ -16,7 +16,8 @@ import ( "github.com/filebrowser/filebrowser/v2/settings" "github.com/filebrowser/filebrowser/v2/storage" "github.com/filebrowser/filebrowser/v2/users" - "github.com/mitchellh/go-homedir" + "github.com/filebrowser/filebrowser/v2/version" + homedir "github.com/mitchellh/go-homedir" "github.com/spf13/cobra" "github.com/spf13/pflag" v "github.com/spf13/viper" @@ -29,6 +30,9 @@ var ( func init() { cobra.OnInitialize(initConfig) + + rootCmd.SetVersionTemplate("File Browser version {{printf \"%s\" .Version}}\n") + flags := rootCmd.Flags() persistent := rootCmd.PersistentFlags() @@ -87,12 +91,13 @@ func mustGetStringViperFlag(flags *pflag.FlagSet, key string) string { } var rootCmd = &cobra.Command{ - Use: "filebrowser", - Short: "A stylish web-based file browser", + Use: "filebrowser", + Short: "A stylish web-based file browser", + Version: version.Version, Long: `File Browser CLI lets you create the database to use with File Browser, manage your users and all the configurations without acessing the web interface. - + If you've never run File Browser, you'll need to have a database for it. Don't worry: you don't need to setup a separate database server. We're using Bolt DB which is a single file database and all managed diff --git a/cmd/rules.go b/cmd/rules.go index 0d0f030e..a0eab30b 100644 --- a/cmd/rules.go +++ b/cmd/rules.go @@ -18,8 +18,9 @@ func init() { } var rulesCmd = &cobra.Command{ - Use: "rules", - Short: "Rules management utility", + Use: "rules", + Version: rootCmd.Version, + Short: "Rules management utility", Long: `On each subcommand you'll have available at least two flags: "username" and "id". You must either set only one of them or none. If you set one of them, the command will apply to diff --git a/cmd/upgrade.go b/cmd/upgrade.go index bdc40a5d..0e3dd290 100644 --- a/cmd/upgrade.go +++ b/cmd/upgrade.go @@ -14,8 +14,9 @@ func init() { } var upgradeCmd = &cobra.Command{ - Use: "upgrade", - Short: "Upgrades an old configuration", + Use: "upgrade", + Version: rootCmd.Version, + Short: "Upgrades an old configuration", Long: `Upgrades an old configuration. This command DOES NOT import share links because they are incompatible with this version.`, diff --git a/cmd/users.go b/cmd/users.go index 74c1c185..b7ec4a8e 100644 --- a/cmd/users.go +++ b/cmd/users.go @@ -18,10 +18,11 @@ func init() { } var usersCmd = &cobra.Command{ - Use: "users", - Short: "Users management utility", - Long: `Users management utility.`, - Args: cobra.NoArgs, + Use: "users", + Version: rootCmd.Version, + Short: "Users management utility", + Long: `Users management utility.`, + Args: cobra.NoArgs, } func printUsers(users []*users.User) { diff --git a/cmd/version.go b/cmd/version.go index b23b928f..61f5b4b4 100644 --- a/cmd/version.go +++ b/cmd/version.go @@ -1,20 +1,32 @@ package cmd import ( - "fmt" + "text/template" - "github.com/filebrowser/filebrowser/v2/version" "github.com/spf13/cobra" ) func init() { rootCmd.AddCommand(versionCmd) + cmdsCmd.AddCommand(versionCmd) + configCmd.AddCommand(versionCmd) + hashCmd.AddCommand(versionCmd) + upgradeCmd.AddCommand(versionCmd) + rulesCmd.AddCommand(versionCmd) + usersCmd.AddCommand(versionCmd) } var versionCmd = &cobra.Command{ Use: "version", - Short: "Print the version number", + Short: "Print the version number of File Browser", + Long: `All software has versions. This is File Browser's`, Run: func(cmd *cobra.Command, args []string) { - fmt.Println("File Browser Version " + version.Version) + // https://github.com/spf13/cobra/issues/724 + t := template.New("version") + template.Must(t.Parse(rootCmd.VersionTemplate())) + err := t.Execute(rootCmd.OutOrStdout(), rootCmd) + if err != nil { + rootCmd.Println(err) + } }, }