error-pages/internal/cli/app.go

92 lines
2.5 KiB
Go
Raw Normal View History

2023-01-29 10:54:56 +00:00
package cli
import (
"context"
"fmt"
"runtime"
"strings"
2024-06-21 13:13:27 +00:00
_ "github.com/urfave/cli-docs/v3" // required for `go generate` to work
"github.com/urfave/cli/v3"
2023-01-29 10:54:56 +00:00
2024-06-21 13:13:27 +00:00
"gh.tarampamp.am/error-pages/internal/appmeta"
2024-06-29 12:34:03 +00:00
"gh.tarampamp.am/error-pages/internal/cli/build"
2024-06-21 23:32:10 +00:00
"gh.tarampamp.am/error-pages/internal/cli/healthcheck"
2024-06-28 22:59:47 +00:00
"gh.tarampamp.am/error-pages/internal/cli/perftest"
2024-06-21 23:32:10 +00:00
"gh.tarampamp.am/error-pages/internal/cli/serve"
"gh.tarampamp.am/error-pages/internal/logger"
2023-01-29 10:54:56 +00:00
)
2024-06-21 13:13:27 +00:00
//go:generate go run update_readme.go
2023-01-29 10:54:56 +00:00
2024-06-21 13:13:27 +00:00
// NewApp creates a new console application.
func NewApp(appName string) *cli.Command { //nolint:funlen
var (
logLevelFlag = cli.StringFlag{
Name: "log-level",
Value: logger.InfoLevel.String(),
Usage: "logging level (" + strings.Join(logger.LevelStrings(), "/") + ")",
2024-06-23 12:12:06 +00:00
Sources: cli.EnvVars("LOG_LEVEL"),
2024-06-21 13:13:27 +00:00
OnlyOnce: true,
Config: cli.StringConfig{TrimSpace: true},
Validator: func(s string) error {
if _, err := logger.ParseLevel(s); err != nil {
2023-01-29 10:54:56 +00:00
return err
}
2024-06-21 13:13:27 +00:00
return nil
},
}
logFormatFlag = cli.StringFlag{
Name: "log-format",
Value: logger.ConsoleFormat.String(),
Usage: "logging format (" + strings.Join(logger.FormatStrings(), "/") + ")",
2024-06-23 12:12:06 +00:00
Sources: cli.EnvVars("LOG_FORMAT"),
2024-06-21 13:13:27 +00:00
OnlyOnce: true,
Config: cli.StringConfig{TrimSpace: true},
Validator: func(s string) error {
if _, err := logger.ParseFormat(s); err != nil {
2023-01-29 10:54:56 +00:00
return err
}
2024-06-21 13:13:27 +00:00
return nil
},
}
)
// create a "default" logger (will be swapped later with customized)
var log, _ = logger.New(logger.InfoLevel, logger.ConsoleFormat) // error will never occur
return &cli.Command{
Usage: appName,
Suggest: true,
Before: func(ctx context.Context, c *cli.Command) error {
var (
logLevel, _ = logger.ParseLevel(c.String(logLevelFlag.Name)) // error ignored because the flag validates itself
logFormat, _ = logger.ParseFormat(c.String(logFormatFlag.Name)) // --//--
)
configured, err := logger.New(logLevel, logFormat) // create a new logger instance
2023-01-29 10:54:56 +00:00
if err != nil {
return err
}
2024-06-21 13:13:27 +00:00
*log = *configured // swap the "default" logger with customized
2023-01-29 10:54:56 +00:00
return nil
},
2024-06-21 23:32:10 +00:00
Commands: []*cli.Command{
serve.NewCommand(log),
2024-06-29 12:34:03 +00:00
build.NewCommand(log),
2024-06-21 23:32:10 +00:00
healthcheck.NewCommand(log, healthcheck.NewHTTPHealthChecker()),
2024-06-28 22:59:47 +00:00
perftest.NewCommand(log),
2024-06-21 23:32:10 +00:00
},
2024-06-21 13:13:27 +00:00
Version: fmt.Sprintf("%s (%s)", appmeta.Version(), runtime.Version()),
2023-01-29 10:54:56 +00:00
Flags: []cli.Flag{ // global flags
2024-06-21 13:13:27 +00:00
&logLevelFlag,
&logFormatFlag,
2023-01-29 10:54:56 +00:00
},
}
}