2022-03-01 03:57:40 +00:00
|
|
|
package paych
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/ipfs/go-cid"
|
|
|
|
|
|
|
|
"github.com/filecoin-project/go-address"
|
|
|
|
"github.com/filecoin-project/go-state-types/abi"
|
|
|
|
"github.com/filecoin-project/go-state-types/big"
|
2022-11-08 04:55:56 +00:00
|
|
|
paych8 "github.com/filecoin-project/go-state-types/builtin/v8/paych"
|
|
|
|
adt8 "github.com/filecoin-project/go-state-types/builtin/v8/util/adt"
|
2022-11-08 05:53:13 +00:00
|
|
|
|
|
|
|
"github.com/filecoin-project/lotus/chain/actors/adt"
|
2022-03-01 03:57:40 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var _ State = (*state8)(nil)
|
|
|
|
|
|
|
|
func load8(store adt.Store, root cid.Cid) (State, error) {
|
|
|
|
out := state8{store: store}
|
|
|
|
err := store.Get(store.Context(), root, &out)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return &out, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func make8(store adt.Store) (State, error) {
|
|
|
|
out := state8{store: store}
|
|
|
|
out.State = paych8.State{}
|
|
|
|
return &out, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type state8 struct {
|
|
|
|
paych8.State
|
|
|
|
store adt.Store
|
|
|
|
lsAmt *adt8.Array
|
|
|
|
}
|
|
|
|
|
|
|
|
// Channel owner, who has funded the actor
|
|
|
|
func (s *state8) From() (address.Address, error) {
|
|
|
|
return s.State.From, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Recipient of payouts from channel
|
|
|
|
func (s *state8) To() (address.Address, error) {
|
|
|
|
return s.State.To, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Height at which the channel can be `Collected`
|
|
|
|
func (s *state8) SettlingAt() (abi.ChainEpoch, error) {
|
|
|
|
return s.State.SettlingAt, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Amount successfully redeemed through the payment channel, paid out on `Collect()`
|
|
|
|
func (s *state8) ToSend() (abi.TokenAmount, error) {
|
|
|
|
return s.State.ToSend, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *state8) getOrLoadLsAmt() (*adt8.Array, error) {
|
|
|
|
if s.lsAmt != nil {
|
|
|
|
return s.lsAmt, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get the lane state from the chain
|
|
|
|
lsamt, err := adt8.AsArray(s.store, s.State.LaneStates, paych8.LaneStatesAmtBitwidth)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
s.lsAmt = lsamt
|
|
|
|
return lsamt, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get total number of lanes
|
|
|
|
func (s *state8) LaneCount() (uint64, error) {
|
|
|
|
lsamt, err := s.getOrLoadLsAmt()
|
|
|
|
if err != nil {
|
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
return lsamt.Length(), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *state8) GetState() interface{} {
|
|
|
|
return &s.State
|
|
|
|
}
|
|
|
|
|
|
|
|
// Iterate lane states
|
|
|
|
func (s *state8) ForEachLaneState(cb func(idx uint64, dl LaneState) error) error {
|
|
|
|
// Get the lane state from the chain
|
|
|
|
lsamt, err := s.getOrLoadLsAmt()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Note: we use a map instead of an array to store laneStates because the
|
|
|
|
// client sets the lane ID (the index) and potentially they could use a
|
|
|
|
// very large index.
|
|
|
|
var ls paych8.LaneState
|
|
|
|
return lsamt.ForEach(&ls, func(i int64) error {
|
|
|
|
return cb(uint64(i), &laneState8{ls})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
type laneState8 struct {
|
|
|
|
paych8.LaneState
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ls *laneState8) Redeemed() (big.Int, error) {
|
|
|
|
return ls.LaneState.Redeemed, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ls *laneState8) Nonce() (uint64, error) {
|
|
|
|
return ls.LaneState.Nonce, nil
|
|
|
|
}
|