Merge pull request #10364 from filecoin-project/chore/rm-market-info-lsm
chore: Remove legacy market info from lotus-miner info
This commit is contained in:
commit
9a2b83064b
@ -7,8 +7,6 @@ import (
|
|||||||
corebig "math/big"
|
corebig "math/big"
|
||||||
"os"
|
"os"
|
||||||
"sort"
|
"sort"
|
||||||
"strings"
|
|
||||||
"text/tabwriter"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/fatih/color"
|
"github.com/fatih/color"
|
||||||
@ -18,8 +16,6 @@ import (
|
|||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
"github.com/filecoin-project/go-address"
|
"github.com/filecoin-project/go-address"
|
||||||
"github.com/filecoin-project/go-fil-markets/retrievalmarket"
|
|
||||||
"github.com/filecoin-project/go-fil-markets/storagemarket"
|
|
||||||
"github.com/filecoin-project/go-state-types/abi"
|
"github.com/filecoin-project/go-state-types/abi"
|
||||||
"github.com/filecoin-project/go-state-types/big"
|
"github.com/filecoin-project/go-state-types/big"
|
||||||
"github.com/filecoin-project/specs-actors/actors/builtin"
|
"github.com/filecoin-project/specs-actors/actors/builtin"
|
||||||
@ -65,12 +61,6 @@ func infoCmdAct(cctx *cli.Context) error {
|
|||||||
}
|
}
|
||||||
defer closer()
|
defer closer()
|
||||||
|
|
||||||
marketsApi, closer, err := lcli.GetMarketsAPI(cctx)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
defer closer()
|
|
||||||
|
|
||||||
fullapi, acloser, err := lcli.GetFullNodeAPIV1(cctx)
|
fullapi, acloser, err := lcli.GetFullNodeAPIV1(cctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -84,14 +74,7 @@ func infoCmdAct(cctx *cli.Context) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Println("Enabled subsystems (from miner API):", subsystems)
|
fmt.Println("Enabled subsystems:", subsystems)
|
||||||
|
|
||||||
subsystems, err = marketsApi.RuntimeSubsystems(ctx)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
fmt.Println("Enabled subsystems (from markets API):", subsystems)
|
|
||||||
|
|
||||||
start, err := minerApi.StartTime(ctx)
|
start, err := minerApi.StartTime(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -128,11 +111,6 @@ func infoCmdAct(cctx *cli.Context) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = handleMarketsInfo(ctx, marketsApi)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -393,105 +371,6 @@ func handleMiningInfo(ctx context.Context, cctx *cli.Context, fullapi v1api.Full
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func handleMarketsInfo(ctx context.Context, nodeApi api.StorageMiner) error {
|
|
||||||
deals, err := nodeApi.MarketListIncompleteDeals(ctx)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
type dealStat struct {
|
|
||||||
count, verifCount int
|
|
||||||
bytes, verifBytes uint64
|
|
||||||
}
|
|
||||||
dsAdd := func(ds *dealStat, deal storagemarket.MinerDeal) {
|
|
||||||
ds.count++
|
|
||||||
ds.bytes += uint64(deal.Proposal.PieceSize)
|
|
||||||
if deal.Proposal.VerifiedDeal {
|
|
||||||
ds.verifCount++
|
|
||||||
ds.verifBytes += uint64(deal.Proposal.PieceSize)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
showDealStates := map[storagemarket.StorageDealStatus]struct{}{
|
|
||||||
storagemarket.StorageDealActive: {},
|
|
||||||
storagemarket.StorageDealAcceptWait: {},
|
|
||||||
storagemarket.StorageDealReserveProviderFunds: {},
|
|
||||||
storagemarket.StorageDealProviderFunding: {},
|
|
||||||
storagemarket.StorageDealTransferring: {},
|
|
||||||
storagemarket.StorageDealValidating: {},
|
|
||||||
storagemarket.StorageDealStaged: {},
|
|
||||||
storagemarket.StorageDealAwaitingPreCommit: {},
|
|
||||||
storagemarket.StorageDealSealing: {},
|
|
||||||
storagemarket.StorageDealPublish: {},
|
|
||||||
storagemarket.StorageDealCheckForAcceptance: {},
|
|
||||||
storagemarket.StorageDealPublishing: {},
|
|
||||||
}
|
|
||||||
|
|
||||||
var total dealStat
|
|
||||||
perState := map[storagemarket.StorageDealStatus]*dealStat{}
|
|
||||||
for _, deal := range deals {
|
|
||||||
if _, ok := showDealStates[deal.State]; !ok {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if perState[deal.State] == nil {
|
|
||||||
perState[deal.State] = new(dealStat)
|
|
||||||
}
|
|
||||||
|
|
||||||
dsAdd(&total, deal)
|
|
||||||
dsAdd(perState[deal.State], deal)
|
|
||||||
}
|
|
||||||
|
|
||||||
type wstr struct {
|
|
||||||
str string
|
|
||||||
status storagemarket.StorageDealStatus
|
|
||||||
}
|
|
||||||
sorted := make([]wstr, 0, len(perState))
|
|
||||||
for status, stat := range perState {
|
|
||||||
st := strings.TrimPrefix(storagemarket.DealStates[status], "StorageDeal")
|
|
||||||
sorted = append(sorted, wstr{
|
|
||||||
str: fmt.Sprintf(" %s:\t%d\t\t%s\t(Verified: %d\t%s)\n", st, stat.count, types.SizeStr(types.NewInt(stat.bytes)), stat.verifCount, types.SizeStr(types.NewInt(stat.verifBytes))),
|
|
||||||
status: status,
|
|
||||||
},
|
|
||||||
)
|
|
||||||
}
|
|
||||||
sort.Slice(sorted, func(i, j int) bool {
|
|
||||||
if sorted[i].status == storagemarket.StorageDealActive || sorted[j].status == storagemarket.StorageDealActive {
|
|
||||||
return sorted[i].status == storagemarket.StorageDealActive
|
|
||||||
}
|
|
||||||
return sorted[i].status > sorted[j].status
|
|
||||||
})
|
|
||||||
|
|
||||||
fmt.Println()
|
|
||||||
fmt.Printf("Storage Deals: %d, %s\n", total.count, types.SizeStr(types.NewInt(total.bytes)))
|
|
||||||
|
|
||||||
tw := tabwriter.NewWriter(os.Stdout, 1, 1, 1, ' ', 0)
|
|
||||||
for _, e := range sorted {
|
|
||||||
_, _ = tw.Write([]byte(e.str))
|
|
||||||
}
|
|
||||||
|
|
||||||
_ = tw.Flush()
|
|
||||||
fmt.Println()
|
|
||||||
|
|
||||||
retrievals, err := nodeApi.MarketListRetrievalDeals(ctx)
|
|
||||||
if err != nil {
|
|
||||||
return xerrors.Errorf("getting retrieval deal list: %w", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
var retrComplete dealStat
|
|
||||||
for _, retrieval := range retrievals {
|
|
||||||
if retrieval.Status == retrievalmarket.DealStatusCompleted {
|
|
||||||
retrComplete.count++
|
|
||||||
retrComplete.bytes += retrieval.TotalSent
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fmt.Printf("Retrieval Deals (complete): %d, %s\n", retrComplete.count, types.SizeStr(types.NewInt(retrComplete.bytes)))
|
|
||||||
|
|
||||||
fmt.Println()
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
type stateMeta struct {
|
type stateMeta struct {
|
||||||
i int
|
i int
|
||||||
col color.Attribute
|
col color.Attribute
|
||||||
|
Loading…
Reference in New Issue
Block a user