44 lines
948 B
Go
44 lines
948 B
Go
package commands
|
|
|
|
import (
|
|
"os"
|
|
|
|
"github.com/spf13/cobra"
|
|
"github.com/spf13/viper"
|
|
|
|
"github.com/tendermint/tmlibs/cli"
|
|
tmflags "github.com/tendermint/tmlibs/cli/flags"
|
|
"github.com/tendermint/tmlibs/log"
|
|
)
|
|
|
|
//nolint
|
|
const (
|
|
defaultLogLevel = "error"
|
|
FlagLogLevel = "log_level"
|
|
)
|
|
|
|
var (
|
|
logger = log.NewTMLogger(log.NewSyncWriter(os.Stdout)).With("module", "main")
|
|
)
|
|
|
|
// RootCmd - main node command
|
|
var RootCmd = &cobra.Command{
|
|
Use: "basecoin",
|
|
Short: "A cryptocurrency framework in Golang based on Tendermint-Core",
|
|
PersistentPreRunE: func(cmd *cobra.Command, args []string) (err error) {
|
|
level := viper.GetString(FlagLogLevel)
|
|
logger, err = tmflags.ParseLogLevel(level, logger, defaultLogLevel)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if viper.GetBool(cli.TraceFlag) {
|
|
logger = log.NewTracingLogger(logger)
|
|
}
|
|
return nil
|
|
},
|
|
}
|
|
|
|
func init() {
|
|
RootCmd.PersistentFlags().String(FlagLogLevel, defaultLogLevel, "Log level")
|
|
}
|