2021-03-17 12:48:38 +02:00

62 lines
1.5 KiB
Go

package main
import (
"os"
"path/filepath"
"github.com/kaspanet/kaspad/infrastructure/config"
"github.com/kaspanet/kaspad/infrastructure/logger"
"github.com/kaspanet/kaspad/stability-tests/common"
"github.com/kaspanet/kaspad/stability-tests/common/rpc"
"github.com/jessevdk/go-flags"
)
const (
defaultLogFilename = "orphans.log"
defaultErrLogFilename = "orphans_err.log"
)
var (
// Default configuration options
defaultLogFile = filepath.Join(common.DefaultAppDir, defaultLogFilename)
defaultErrLogFile = filepath.Join(common.DefaultAppDir, defaultErrLogFilename)
)
type configFlags struct {
rpc.Config
NodeP2PAddress string `long:"addr" short:"a" description:"node's P2P address"`
Profile string `long:"profile" description:"Enable HTTP profiling on given port -- NOTE port must be between 1024 and 65536"`
OrphanChainLength int `long:"num-orphans" short:"n" description:"Desired length of orphan chain"`
config.NetworkFlags
}
var cfg *configFlags
func activeConfig() *configFlags {
return cfg
}
func parseConfig() error {
cfg = &configFlags{}
parser := flags.NewParser(cfg, flags.PrintErrors|flags.HelpFlag)
_, err := parser.Parse()
if err != nil {
if err, ok := err.(*flags.Error); ok && err.Type == flags.ErrHelp {
os.Exit(0)
}
return err
}
err = cfg.ResolveNetwork(parser)
if err != nil {
return err
}
log.SetLevel(logger.LevelInfo)
common.InitBackend(backendLog, defaultLogFile, defaultErrLogFile)
return nil
}