Merge pull request #1349 from filecoin-project/feat/chain-get-types
add some type info to chain get
This commit is contained in:
commit
c553a6f458
@ -47,7 +47,7 @@ type FullNode interface {
|
|||||||
ChainSetHead(context.Context, types.TipSetKey) error
|
ChainSetHead(context.Context, types.TipSetKey) error
|
||||||
ChainGetGenesis(context.Context) (*types.TipSet, error)
|
ChainGetGenesis(context.Context) (*types.TipSet, error)
|
||||||
ChainTipSetWeight(context.Context, types.TipSetKey) (types.BigInt, error)
|
ChainTipSetWeight(context.Context, types.TipSetKey) (types.BigInt, error)
|
||||||
ChainGetNode(ctx context.Context, p string) (interface{}, error)
|
ChainGetNode(ctx context.Context, p string) (*IpldObject, error)
|
||||||
ChainGetMessage(context.Context, cid.Cid) (*types.Message, error)
|
ChainGetMessage(context.Context, cid.Cid) (*types.Message, error)
|
||||||
ChainGetPath(ctx context.Context, from types.TipSetKey, to types.TipSetKey) ([]*store.HeadChange, error)
|
ChainGetPath(ctx context.Context, from types.TipSetKey, to types.TipSetKey) ([]*store.HeadChange, error)
|
||||||
ChainExport(context.Context, types.TipSetKey) (<-chan []byte, error)
|
ChainExport(context.Context, types.TipSetKey) (<-chan []byte, error)
|
||||||
@ -319,6 +319,11 @@ type StartDealParams struct {
|
|||||||
BlocksDuration uint64
|
BlocksDuration uint64
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type IpldObject struct {
|
||||||
|
Cid cid.Cid
|
||||||
|
Obj interface{}
|
||||||
|
}
|
||||||
|
|
||||||
type ActiveSync struct {
|
type ActiveSync struct {
|
||||||
Base *types.TipSet
|
Base *types.TipSet
|
||||||
Target *types.TipSet
|
Target *types.TipSet
|
||||||
|
@ -64,7 +64,7 @@ type FullNodeStruct struct {
|
|||||||
ChainSetHead func(context.Context, types.TipSetKey) error `perm:"admin"`
|
ChainSetHead func(context.Context, types.TipSetKey) error `perm:"admin"`
|
||||||
ChainGetGenesis func(context.Context) (*types.TipSet, error) `perm:"read"`
|
ChainGetGenesis func(context.Context) (*types.TipSet, error) `perm:"read"`
|
||||||
ChainTipSetWeight func(context.Context, types.TipSetKey) (types.BigInt, error) `perm:"read"`
|
ChainTipSetWeight func(context.Context, types.TipSetKey) (types.BigInt, error) `perm:"read"`
|
||||||
ChainGetNode func(ctx context.Context, p string) (interface{}, error) `perm:"read"`
|
ChainGetNode func(ctx context.Context, p string) (*api.IpldObject, error) `perm:"read"`
|
||||||
ChainGetMessage func(context.Context, cid.Cid) (*types.Message, error) `perm:"read"`
|
ChainGetMessage func(context.Context, cid.Cid) (*types.Message, error) `perm:"read"`
|
||||||
ChainGetPath func(context.Context, types.TipSetKey, types.TipSetKey) ([]*store.HeadChange, error) `perm:"read"`
|
ChainGetPath func(context.Context, types.TipSetKey, types.TipSetKey) ([]*store.HeadChange, error) `perm:"read"`
|
||||||
ChainExport func(context.Context, types.TipSetKey) (<-chan []byte, error) `perm:"read"`
|
ChainExport func(context.Context, types.TipSetKey) (<-chan []byte, error) `perm:"read"`
|
||||||
@ -397,7 +397,7 @@ func (c *FullNodeStruct) ChainTipSetWeight(ctx context.Context, tsk types.TipSet
|
|||||||
return c.Internal.ChainTipSetWeight(ctx, tsk)
|
return c.Internal.ChainTipSetWeight(ctx, tsk)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *FullNodeStruct) ChainGetNode(ctx context.Context, p string) (interface{}, error) {
|
func (c *FullNodeStruct) ChainGetNode(ctx context.Context, p string) (*api.IpldObject, error) {
|
||||||
return c.Internal.ChainGetNode(ctx, p)
|
return c.Internal.ChainGetNode(ctx, p)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
44
cli/chain.go
44
cli/chain.go
@ -17,6 +17,7 @@ import (
|
|||||||
"github.com/filecoin-project/specs-actors/actors/builtin"
|
"github.com/filecoin-project/specs-actors/actors/builtin"
|
||||||
"github.com/filecoin-project/specs-actors/actors/builtin/power"
|
"github.com/filecoin-project/specs-actors/actors/builtin/power"
|
||||||
cid "github.com/ipfs/go-cid"
|
cid "github.com/ipfs/go-cid"
|
||||||
|
cbg "github.com/whyrusleeping/cbor-gen"
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
"gopkg.in/urfave/cli.v2"
|
"gopkg.in/urfave/cli.v2"
|
||||||
|
|
||||||
@ -407,6 +408,12 @@ var chainGetCmd = &cli.Command{
|
|||||||
Name: "get",
|
Name: "get",
|
||||||
Usage: "Get chain DAG node by path",
|
Usage: "Get chain DAG node by path",
|
||||||
ArgsUsage: "[path]",
|
ArgsUsage: "[path]",
|
||||||
|
Flags: []cli.Flag{
|
||||||
|
&cli.StringFlag{
|
||||||
|
Name: "as-type",
|
||||||
|
Usage: "specify type to interpret output as",
|
||||||
|
},
|
||||||
|
},
|
||||||
Description: `Get ipld node under a specified path:
|
Description: `Get ipld node under a specified path:
|
||||||
|
|
||||||
lotus chain get /ipfs/[cid]/some/path
|
lotus chain get /ipfs/[cid]/some/path
|
||||||
@ -425,12 +432,45 @@ var chainGetCmd = &cli.Command{
|
|||||||
defer closer()
|
defer closer()
|
||||||
ctx := ReqContext(cctx)
|
ctx := ReqContext(cctx)
|
||||||
|
|
||||||
nd, err := api.ChainGetNode(ctx, cctx.Args().First())
|
obj, err := api.ChainGetNode(ctx, cctx.Args().First())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
b, err := json.MarshalIndent(nd, "", "\t")
|
t := strings.ToLower(cctx.String("as-type"))
|
||||||
|
if t == "" {
|
||||||
|
b, err := json.MarshalIndent(obj.Obj, "", "\t")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
fmt.Println(string(b))
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var cbu cbg.CBORUnmarshaler
|
||||||
|
switch t {
|
||||||
|
case "block":
|
||||||
|
cbu = new(types.BlockHeader)
|
||||||
|
case "message":
|
||||||
|
cbu = new(types.Message)
|
||||||
|
case "smessage", "signedmessage":
|
||||||
|
cbu = new(types.SignedMessage)
|
||||||
|
case "actor":
|
||||||
|
cbu = new(types.Actor)
|
||||||
|
default:
|
||||||
|
return fmt.Errorf("unknown type: %q", t)
|
||||||
|
}
|
||||||
|
|
||||||
|
raw, err := api.ChainReadObj(ctx, obj.Cid)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := cbu.UnmarshalCBOR(bytes.NewReader(raw)); err != nil {
|
||||||
|
return fmt.Errorf("failed to unmarshal as %q", t)
|
||||||
|
}
|
||||||
|
|
||||||
|
b, err := json.MarshalIndent(cbu, "", "\t")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -356,7 +356,7 @@ func resolveOnce(bs blockstore.Blockstore) func(ctx context.Context, ds ipld.Nod
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *ChainAPI) ChainGetNode(ctx context.Context, p string) (interface{}, error) {
|
func (a *ChainAPI) ChainGetNode(ctx context.Context, p string) (*api.IpldObject, error) {
|
||||||
ip, err := path.ParsePath(p)
|
ip, err := path.ParsePath(p)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, xerrors.Errorf("parsing path: %w", err)
|
return nil, xerrors.Errorf("parsing path: %w", err)
|
||||||
@ -377,7 +377,10 @@ func (a *ChainAPI) ChainGetNode(ctx context.Context, p string) (interface{}, err
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return node, nil
|
return &api.IpldObject{
|
||||||
|
Cid: node.Cid(),
|
||||||
|
Obj: node,
|
||||||
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *ChainAPI) ChainGetMessage(ctx context.Context, mc cid.Cid) (*types.Message, error) {
|
func (a *ChainAPI) ChainGetMessage(ctx context.Context, mc cid.Cid) (*types.Message, error) {
|
||||||
|
Loading…
Reference in New Issue
Block a user