package main import ( "context" "os" "github.com/fatih/color" logging "github.com/ipfs/go-log/v2" "github.com/mattn/go-isatty" "github.com/urfave/cli/v2" "go.opencensus.io/trace" "github.com/filecoin-project/lotus/api" "github.com/filecoin-project/lotus/build" lcli "github.com/filecoin-project/lotus/cli" cliutil "github.com/filecoin-project/lotus/cli/util" "github.com/filecoin-project/lotus/lib/lotuslog" "github.com/filecoin-project/lotus/lib/tracing" "github.com/filecoin-project/lotus/node/repo" ) var log = logging.Logger("main") var AdvanceBlockCmd *cli.Command func main() { api.RunningNodeType = api.NodeFull lotuslog.SetupLogLevels() local := []*cli.Command{ DaemonCmd, backupCmd, configCmd, } if AdvanceBlockCmd != nil { local = append(local, AdvanceBlockCmd) } jaeger := tracing.SetupJaegerTracing("lotus") defer func() { if jaeger != nil { _ = jaeger.ForceFlush(context.Background()) } }() for _, cmd := range local { cmd := cmd originBefore := cmd.Before cmd.Before = func(cctx *cli.Context) error { if jaeger != nil { _ = jaeger.Shutdown(cctx.Context) } jaeger = tracing.SetupJaegerTracing("lotus/" + cmd.Name) if cctx.IsSet("color") { color.NoColor = !cctx.Bool("color") } if originBefore != nil { return originBefore(cctx) } return nil } } ctx, span := trace.StartSpan(context.Background(), "/cli") defer span.End() interactiveDef := isatty.IsTerminal(os.Stdout.Fd()) || isatty.IsCygwinTerminal(os.Stdout.Fd()) app := &cli.App{ Name: "lotus", Usage: "Filecoin decentralized storage network client", Version: build.UserVersion(), EnableBashCompletion: true, Flags: []cli.Flag{ &cli.StringFlag{ Name: "panic-reports", EnvVars: []string{"LOTUS_PANIC_REPORT_PATH"}, Hidden: true, Value: "~/.lotus", // should follow --repo default }, &cli.BoolFlag{ // examined in the Before above Name: "color", Usage: "use color in display output", DefaultText: "depends on output being a TTY", }, &cli.StringFlag{ Name: "repo", EnvVars: []string{"LOTUS_PATH"}, Hidden: true, Value: "~/.lotus", // TODO: Consider XDG_DATA_HOME }, &cli.BoolFlag{ Name: "interactive", Usage: "setting to false will disable interactive functionality of commands", Value: interactiveDef, }, &cli.BoolFlag{ Name: "force-send", Usage: "if true, will ignore pre-send checks", }, cliutil.FlagVeryVerbose, }, After: func(c *cli.Context) error { if r := recover(); r != nil { // Generate report in LOTUS_PATH and re-raise panic build.GeneratePanicReport(c.String("panic-reports"), c.String("repo"), c.App.Name) panic(r) } return nil }, Commands: append(local, lcli.Commands...), } app.Setup() app.Metadata["traceContext"] = ctx app.Metadata["repoType"] = repo.FullNode lcli.RunApp(app) }