package power import ( "github.com/filecoin-project/go-address" "github.com/filecoin-project/go-state-types/abi" "github.com/ipfs/go-cid" "github.com/filecoin-project/lotus/chain/actors/adt" "github.com/filecoin-project/lotus/chain/actors/builtin" power2 "github.com/filecoin-project/specs-actors/v2/actors/builtin/power" adt2 "github.com/filecoin-project/specs-actors/v2/actors/util/adt" ) var _ State = (*state2)(nil) func load2(store adt.Store, root cid.Cid) (State, error) { out := state2{store: store} err := store.Get(store.Context(), root, &out) if err != nil { return nil, err } return &out, nil } type state2 struct { power2.State store adt.Store } func (s *state2) TotalLocked() (abi.TokenAmount, error) { return s.TotalPledgeCollateral, nil } func (s *state2) TotalPower() (Claim, error) { return Claim{ RawBytePower: s.TotalRawBytePower, QualityAdjPower: s.TotalQualityAdjPower, }, nil } // Committed power to the network. Includes miners below the minimum threshold. func (s *state2) TotalCommitted() (Claim, error) { return Claim{ RawBytePower: s.TotalBytesCommitted, QualityAdjPower: s.TotalQABytesCommitted, }, nil } func (s *state2) MinerPower(addr address.Address) (Claim, bool, error) { claims, err := adt2.AsMap(s.store, s.Claims) if err != nil { return Claim{}, false, err } var claim power2.Claim ok, err := claims.Get(abi.AddrKey(addr), &claim) if err != nil { return Claim{}, false, err } return Claim{ RawBytePower: claim.RawBytePower, QualityAdjPower: claim.QualityAdjPower, }, ok, nil } func (s *state2) MinerNominalPowerMeetsConsensusMinimum(a address.Address) (bool, error) { return s.State.MinerNominalPowerMeetsConsensusMinimum(s.store, a) } func (s *state2) TotalPowerSmoothed() (builtin.FilterEstimate, error) { return builtin.FromV2FilterEstimate(s.State.ThisEpochQAPowerSmoothed), nil } func (s *state2) MinerCounts() (uint64, uint64, error) { return uint64(s.State.MinerAboveMinPowerCount), uint64(s.State.MinerCount), nil } func (s *state2) ListAllMiners() ([]address.Address, error) { claims, err := adt2.AsMap(s.store, s.Claims) if err != nil { return nil, err } var miners []address.Address err = claims.ForEach(nil, func(k string) error { a, err := address.NewFromBytes([]byte(k)) if err != nil { return err } miners = append(miners, a) return nil }) if err != nil { return nil, err } return miners, nil } func (s *state2) ForEachClaim(cb func(miner address.Address, claim Claim) error) error { claims, err := adt2.AsMap(s.store, s.Claims) if err != nil { return err } var claim power2.Claim return claims.ForEach(&claim, func(k string) error { a, err := address.NewFromBytes([]byte(k)) if err != nil { return err } return cb(a, Claim{ RawBytePower: claim.RawBytePower, QualityAdjPower: claim.QualityAdjPower, }) }) }