Compare commits

...

2 Commits

Author SHA1 Message Date
b37a283dfb Refactor flags
All checks were successful
Gitea Actions Demo / Explore-Gitea-Actions (push) Successful in 4s
Signed-off-by: Jan Tytgat <jan.tytgat@corelayer.eu>
2025-06-09 22:36:45 +02:00
ee7cb7e422 Remove dependency on semver package
Signed-off-by: Jan Tytgat <jan.tytgat@corelayer.eu>
2025-06-09 22:36:32 +02:00
4 changed files with 29 additions and 17 deletions

View File

@ -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

View File

@ -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

View File

@ -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) {

View File

@ -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) {