Some checks are pending
docker-build-cometbft / vars (push) Waiting to run
docker-build-cometbft / build-images (amd64, ubuntu-24.04) (push) Blocked by required conditions
docker-build-cometbft / build-images (arm64, ubuntu-24.04-arm) (push) Blocked by required conditions
docker-build-cometbft / merge-images (push) Blocked by required conditions
docker-build-e2e-node / vars (push) Waiting to run
docker-build-e2e-node / build-images (amd64, ubuntu-24.04) (push) Blocked by required conditions
docker-build-e2e-node / build-images (arm64, ubuntu-24.04-arm) (push) Blocked by required conditions
docker-build-e2e-node / merge-images (push) Blocked by required conditions
97 lines
2.4 KiB
Go
97 lines
2.4 KiB
Go
package commands
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
|
|
"github.com/spf13/cobra"
|
|
"github.com/spf13/viper"
|
|
|
|
cfg "git.cw.tr/mukan-network/mukan-consensus/config"
|
|
"git.cw.tr/mukan-network/mukan-consensus/libs/cli"
|
|
cmtflags "git.cw.tr/mukan-network/mukan-consensus/libs/cli/flags"
|
|
"git.cw.tr/mukan-network/mukan-consensus/libs/log"
|
|
)
|
|
|
|
var (
|
|
config = cfg.DefaultConfig()
|
|
logger = log.NewTMLogger(log.NewSyncWriter(os.Stdout))
|
|
)
|
|
|
|
func init() {
|
|
registerFlagsRootCmd(RootCmd)
|
|
}
|
|
|
|
func registerFlagsRootCmd(cmd *cobra.Command) {
|
|
cmd.PersistentFlags().String("log_level", config.LogLevel, "log level")
|
|
}
|
|
|
|
// ParseConfig retrieves the default environment configuration,
|
|
// sets up the CometBFT root and ensures that the root exists
|
|
func ParseConfig(cmd *cobra.Command) (*cfg.Config, error) {
|
|
conf := cfg.DefaultConfig()
|
|
err := viper.Unmarshal(conf)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var home string
|
|
if os.Getenv("CMTHOME") != "" {
|
|
home = os.Getenv("CMTHOME")
|
|
} else if os.Getenv("TMHOME") != "" {
|
|
// XXX: Deprecated.
|
|
home = os.Getenv("TMHOME")
|
|
logger.Error("Deprecated environment variable TMHOME identified. CMTHOME should be used instead.")
|
|
} else {
|
|
home, err = cmd.Flags().GetString(cli.HomeFlag)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
|
|
conf.RootDir = home
|
|
|
|
conf.SetRoot(conf.RootDir)
|
|
cfg.EnsureRoot(conf.RootDir)
|
|
if err := conf.ValidateBasic(); err != nil {
|
|
return nil, fmt.Errorf("error in config file: %v", err)
|
|
}
|
|
if warnings := conf.CheckDeprecated(); len(warnings) > 0 {
|
|
for _, warning := range warnings {
|
|
logger.Info("deprecated usage found in configuration file", "usage", warning)
|
|
}
|
|
}
|
|
return conf, nil
|
|
}
|
|
|
|
// RootCmd is the root command for CometBFT core.
|
|
var RootCmd = &cobra.Command{
|
|
Use: "cometbft",
|
|
Short: "BFT state machine replication for applications in any programming languages",
|
|
PersistentPreRunE: func(cmd *cobra.Command, args []string) (err error) {
|
|
if cmd.Name() == VersionCmd.Name() {
|
|
return nil
|
|
}
|
|
|
|
config, err = ParseConfig(cmd)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if config.LogFormat == cfg.LogFormatJSON {
|
|
logger = log.NewTMJSONLogger(log.NewSyncWriter(os.Stdout))
|
|
}
|
|
|
|
logger, err = cmtflags.ParseLogLevel(config.LogLevel, logger, cfg.DefaultLogLevel)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if viper.GetBool(cli.TraceFlag) {
|
|
logger = log.NewTracingLogger(logger)
|
|
}
|
|
|
|
logger = logger.With("module", "main")
|
|
return nil
|
|
},
|
|
}
|