Compare commits
2 Commits
fa641b06b2
...
b37a283dfb
Author | SHA1 | Date | |
---|---|---|---|
b37a283dfb | |||
ee7cb7e422 |
@ -8,8 +8,6 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
"git.flexabyte.io/flexabyte/go-kit/semver"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type Config struct {
|
type Config struct {
|
||||||
@ -99,8 +97,7 @@ func (c Config) Validate() error {
|
|||||||
return errors.New("logger is required")
|
return errors.New("logger is required")
|
||||||
}
|
}
|
||||||
|
|
||||||
var err error
|
if !c.Version.IsValid() {
|
||||||
if _, err = semver.Parse(c.Version.Full); err != nil {
|
|
||||||
return fmt.Errorf("invalid version: %s", c.Version)
|
return fmt.Errorf("invalid version: %s", c.Version)
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
@ -50,7 +50,7 @@ func persistentPreRunFuncE(cmd *cobra.Command, args []string) error {
|
|||||||
slogd.FromContext(cmd.Context()).Log(cmd.Context(), slogd.LevelTrace, "executing PersistentPreRun")
|
slogd.FromContext(cmd.Context()).Log(cmd.Context(), slogd.LevelTrace, "executing PersistentPreRun")
|
||||||
|
|
||||||
// Make sure we can always get the version
|
// Make sure we can always get the version
|
||||||
if versionFlag.Value || cmd.CommandPath() == strings.Join([]string{appName, versionName}, " ") {
|
if versionFlag.Value || cmd.CommandPath() == strings.Join([]string{appName, versionFlagName}, " ") {
|
||||||
slogd.FromContext(cmd.Context()).LogAttrs(cmd.Context(), slogd.LevelTrace, "overriding command", slog.String("old_function", runtime.FuncForPC(reflect.ValueOf(cmd.RunE).Pointer()).Name()), slog.String("new_function", runtime.FuncForPC(reflect.ValueOf(versionRunFuncE).Pointer()).Name()))
|
slogd.FromContext(cmd.Context()).LogAttrs(cmd.Context(), slogd.LevelTrace, "overriding command", slog.String("old_function", runtime.FuncForPC(reflect.ValueOf(cmd.RunE).Pointer()).Name()), slog.String("new_function", runtime.FuncForPC(reflect.ValueOf(versionRunFuncE).Pointer()).Name()))
|
||||||
cmd.RunE = versionRunFuncE
|
cmd.RunE = versionRunFuncE
|
||||||
return nil
|
return nil
|
||||||
|
@ -8,8 +8,12 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
quietFlagShortCode = "q"
|
jsonOutputFlagDefault = false
|
||||||
verboseFlagShortCode = "v"
|
noColorFlagDefault = false
|
||||||
|
quietFlagDefault = false
|
||||||
|
quietFlagShortCode = "q"
|
||||||
|
verboseFlagDefault = false
|
||||||
|
verboseFlagShortCode = "v"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -20,19 +24,19 @@ var (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func addJsonOutputFlag(cmd *cobra.Command) {
|
func addJsonOutputFlag(cmd *cobra.Command) {
|
||||||
cmd.PersistentFlags().BoolVarP(&jsonOutputFlag.Value, jsonOutputFlag.Name(), "", false, jsonOutputFlag.Usage())
|
cmd.PersistentFlags().BoolVarP(&jsonOutputFlag.Value, jsonOutputFlag.Name(), "", jsonOutputFlagDefault, jsonOutputFlag.Usage())
|
||||||
}
|
}
|
||||||
|
|
||||||
func addNoColorFlag(cmd *cobra.Command) {
|
func addNoColorFlag(cmd *cobra.Command) {
|
||||||
cmd.PersistentFlags().BoolVarP(&noColorFlag.Value, noColorFlag.Name(), "", false, noColorFlag.Usage())
|
cmd.PersistentFlags().BoolVarP(&noColorFlag.Value, noColorFlag.Name(), "", noColorFlagDefault, noColorFlag.Usage())
|
||||||
}
|
}
|
||||||
|
|
||||||
func addQuietFlag(cmd *cobra.Command) {
|
func addQuietFlag(cmd *cobra.Command) {
|
||||||
cmd.PersistentFlags().BoolVarP(&quietFlag.Value, quietFlag.Name(), quietFlagShortCode, false, quietFlag.Usage())
|
cmd.PersistentFlags().BoolVarP(&quietFlag.Value, quietFlag.Name(), quietFlagShortCode, quietFlagDefault, quietFlag.Usage())
|
||||||
}
|
}
|
||||||
|
|
||||||
func addVerboseFlag(cmd *cobra.Command) {
|
func addVerboseFlag(cmd *cobra.Command) {
|
||||||
cmd.PersistentFlags().BoolVarP(&verboseFlag.Value, verboseFlag.Name(), verboseFlagShortCode, false, verboseFlag.Usage())
|
cmd.PersistentFlags().BoolVarP(&verboseFlag.Value, verboseFlag.Name(), verboseFlagShortCode, verboseFlagDefault, verboseFlag.Usage())
|
||||||
}
|
}
|
||||||
|
|
||||||
func configureOutputFlags(cmd *cobra.Command) {
|
func configureOutputFlags(cmd *cobra.Command) {
|
||||||
|
@ -3,6 +3,7 @@ package application
|
|||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"regexp"
|
||||||
|
|
||||||
"github.com/Oudwins/zog"
|
"github.com/Oudwins/zog"
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
@ -11,19 +12,25 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
versionName = "version"
|
versionFlagName = "version"
|
||||||
versionFlagShortCode = "V"
|
versionFlagShortCode = "V"
|
||||||
versionUsage = "Show version information"
|
versionFlagUsage = "Show version information"
|
||||||
|
versionFlagDefault = false
|
||||||
|
|
||||||
|
// https://semver.org/ && https://regex101.com/r/Ly7O1x/3/
|
||||||
|
validSemVer = `^(?P<major>0|[1-9]\d*)\.(?P<minor>0|[1-9]\d*)\.(?P<patch>0|[1-9]\d*)(?:-(?P<prerelease>(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+(?P<buildmetadata>[0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$`
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
versionFlag = flagzog.NewBoolFlag(versionName, zog.Bool(), versionUsage)
|
versionFlag = flagzog.NewBoolFlag(versionFlagName, zog.Bool(), versionFlagUsage)
|
||||||
version Version
|
version Version
|
||||||
versionCmd = &cobra.Command{
|
versionCmd = &cobra.Command{
|
||||||
Use: versionName,
|
Use: versionFlagName,
|
||||||
Short: versionUsage,
|
Short: versionFlagUsage,
|
||||||
RunE: versionRunFuncE,
|
RunE: versionRunFuncE,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
regexSemver = regexp.MustCompile(validSemVer)
|
||||||
)
|
)
|
||||||
|
|
||||||
type Version struct {
|
type Version struct {
|
||||||
@ -39,8 +46,12 @@ type Version struct {
|
|||||||
PreRelease string
|
PreRelease string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (v Version) IsValid() bool {
|
||||||
|
return regexSemver.MatchString(v.Full)
|
||||||
|
}
|
||||||
|
|
||||||
func addVersionFlag(cmd *cobra.Command) {
|
func addVersionFlag(cmd *cobra.Command) {
|
||||||
cmd.PersistentFlags().BoolVarP(&versionFlag.Value, versionFlag.Name(), versionFlagShortCode, false, versionFlag.Usage())
|
cmd.PersistentFlags().BoolVarP(&versionFlag.Value, versionFlag.Name(), versionFlagShortCode, versionFlagDefault, versionFlag.Usage())
|
||||||
}
|
}
|
||||||
|
|
||||||
func configureVersionFlag(cmd *cobra.Command, v Version) {
|
func configureVersionFlag(cmd *cobra.Command, v Version) {
|
||||||
|
Reference in New Issue
Block a user