package main import ( "fmt" "sort" "github.com/urfave/cli/v2" "golang.org/x/xerrors" "github.com/filecoin-project/lotus/chain/types" lcli "github.com/filecoin-project/lotus/cli" "github.com/filecoin-project/lotus/storage/sealer/sealtasks" ) var infoCmd = &cli.Command{ Name: "info", Usage: "Print worker info", Action: func(cctx *cli.Context) error { api, closer, err := lcli.GetWorkerAPI(cctx) if err != nil { return err } defer closer() ctx := lcli.ReqContext(cctx) ver, err := api.Version(ctx) if err != nil { return xerrors.Errorf("getting version: %w", err) } fmt.Println("Worker version: ", ver) fmt.Print("CLI version: ") cli.VersionPrinter(cctx) fmt.Println() sess, err := api.ProcessSession(ctx) if err != nil { return xerrors.Errorf("getting session: %w", err) } fmt.Printf("Session: %s\n", sess) enabled, err := api.Enabled(ctx) if err != nil { return xerrors.Errorf("checking worker status: %w", err) } fmt.Printf("Enabled: %t\n", enabled) info, err := api.Info(ctx) if err != nil { return xerrors.Errorf("getting info: %w", err) } tt, err := api.TaskTypes(ctx) if err != nil { return xerrors.Errorf("getting task types: %w", err) } fmt.Printf("Hostname: %s\n", info.Hostname) fmt.Printf("CPUs: %d; GPUs: %v\n", info.Resources.CPUs, info.Resources.GPUs) fmt.Printf("RAM: %s/%s; Swap: %s/%s\n", types.SizeStr(types.NewInt(info.Resources.MemUsed)), types.SizeStr(types.NewInt(info.Resources.MemPhysical)), types.SizeStr(types.NewInt(info.Resources.MemSwapUsed)), types.SizeStr(types.NewInt(info.Resources.MemSwap))) fmt.Printf("Task types: ") for _, t := range ttList(tt) { fmt.Printf("%s ", t.Short()) } fmt.Println() fmt.Println() paths, err := api.Paths(ctx) if err != nil { return xerrors.Errorf("getting path info: %w", err) } for _, path := range paths { fmt.Printf("%s:\n", path.ID) fmt.Printf("\tWeight: %d; Use: ", path.Weight) if path.CanSeal || path.CanStore { if path.CanSeal { fmt.Print("Seal ") } if path.CanStore { fmt.Print("Store") } fmt.Println("") } else { fmt.Print("Use: ReadOnly") } fmt.Printf("\tLocal: %s\n", path.LocalPath) } return nil }, } func ttList(tt map[sealtasks.TaskType]struct{}) []sealtasks.TaskType { tasks := make([]sealtasks.TaskType, 0, len(tt)) for taskType := range tt { tasks = append(tasks, taskType) } sort.Slice(tasks, func(i, j int) bool { return tasks[i].Less(tasks[j]) }) return tasks }