f907354300
The naming of `LookupID` can cause confusion when resolving actor IDs vs ID addresses. To avoid this: * Refactor `StateTree` `LookupID` to `LookupIDAddress`, because it returns ID address. * Refactor `StateManager` `LookupID` to `LookupIDAddress` because it also returns ID address via a chain call to `StateTree`. * Introduce a new API `StateManager` dedicated to resolving address to actor ID, called `LookupID` which returns `abi.ActorID`. For context, see: * https://github.com/filecoin-project/lotus/pull/11723#discussion_r1534728607
60 lines
1.9 KiB
Go
60 lines
1.9 KiB
Go
package rpcstmgr
|
|
|
|
import (
|
|
"context"
|
|
|
|
cbor "github.com/ipfs/go-ipld-cbor"
|
|
"golang.org/x/xerrors"
|
|
|
|
"github.com/filecoin-project/go-address"
|
|
|
|
"github.com/filecoin-project/lotus/api"
|
|
"github.com/filecoin-project/lotus/blockstore"
|
|
"github.com/filecoin-project/lotus/chain/actors/adt"
|
|
"github.com/filecoin-project/lotus/chain/actors/builtin/paych"
|
|
"github.com/filecoin-project/lotus/chain/stmgr"
|
|
"github.com/filecoin-project/lotus/chain/types"
|
|
)
|
|
|
|
type RPCStateManager struct {
|
|
gapi api.Gateway
|
|
cstore *cbor.BasicIpldStore
|
|
}
|
|
|
|
func NewRPCStateManager(api api.Gateway) *RPCStateManager {
|
|
cstore := cbor.NewCborStore(blockstore.NewAPIBlockstore(api))
|
|
return &RPCStateManager{gapi: api, cstore: cstore}
|
|
}
|
|
|
|
func (s *RPCStateManager) GetPaychState(ctx context.Context, addr address.Address, ts *types.TipSet) (*types.Actor, paych.State, error) {
|
|
act, err := s.gapi.StateGetActor(ctx, addr, ts.Key())
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
actState, err := paych.Load(adt.WrapStore(ctx, s.cstore), act)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
return act, actState, nil
|
|
|
|
}
|
|
|
|
func (s *RPCStateManager) LoadActorTsk(ctx context.Context, addr address.Address, tsk types.TipSetKey) (*types.Actor, error) {
|
|
return s.gapi.StateGetActor(ctx, addr, tsk)
|
|
}
|
|
|
|
func (s *RPCStateManager) LookupIDAddress(ctx context.Context, addr address.Address, ts *types.TipSet) (address.Address, error) {
|
|
return s.gapi.StateLookupID(ctx, addr, ts.Key())
|
|
}
|
|
|
|
func (s *RPCStateManager) ResolveToDeterministicAddress(ctx context.Context, addr address.Address, ts *types.TipSet) (address.Address, error) {
|
|
return s.gapi.StateAccountKey(ctx, addr, ts.Key())
|
|
}
|
|
|
|
func (s *RPCStateManager) Call(ctx context.Context, msg *types.Message, ts *types.TipSet) (*api.InvocResult, error) {
|
|
return nil, xerrors.Errorf("RPCStateManager does not implement StateManager.Call")
|
|
}
|
|
|
|
var _ stmgr.StateManagerAPI = (*RPCStateManager)(nil)
|