set up lotus-storage-miner to be able to use an existing miner actor

This commit is contained in:
whyrusleeping 2019-08-16 14:50:00 -07:00
parent d9eaca5527
commit b271e5231a
2 changed files with 172 additions and 76 deletions

View File

@ -2,6 +2,7 @@ package actors
import ( import (
"context" "context"
"github.com/filecoin-project/go-lotus/chain/actors/aerrors" "github.com/filecoin-project/go-lotus/chain/actors/aerrors"
"github.com/filecoin-project/go-lotus/chain/address" "github.com/filecoin-project/go-lotus/chain/address"
"github.com/filecoin-project/go-lotus/chain/types" "github.com/filecoin-project/go-lotus/chain/types"
@ -22,6 +23,7 @@ func init() {
cbor.RegisterCborType(PieceInclVoucherData{}) cbor.RegisterCborType(PieceInclVoucherData{})
cbor.RegisterCborType(InclusionProof{}) cbor.RegisterCborType(InclusionProof{})
cbor.RegisterCborType(PaymentVerifyParams{}) cbor.RegisterCborType(PaymentVerifyParams{})
cbor.RegisterCborType(UpdatePeerIDParams{})
} }
var ProvingPeriodDuration = uint64(2 * 60) // an hour, for now var ProvingPeriodDuration = uint64(2 * 60) // an hour, for now

View File

@ -1,11 +1,14 @@
package main package main
import ( import (
"context"
"github.com/ipfs/go-datastore" "github.com/ipfs/go-datastore"
"github.com/libp2p/go-libp2p-core/peer" "github.com/libp2p/go-libp2p-core/peer"
"golang.org/x/xerrors" "golang.org/x/xerrors"
"gopkg.in/urfave/cli.v2" "gopkg.in/urfave/cli.v2"
"github.com/filecoin-project/go-lotus/api"
"github.com/filecoin-project/go-lotus/build" "github.com/filecoin-project/go-lotus/build"
"github.com/filecoin-project/go-lotus/chain/actors" "github.com/filecoin-project/go-lotus/chain/actors"
"github.com/filecoin-project/go-lotus/chain/address" "github.com/filecoin-project/go-lotus/chain/address"
@ -17,6 +20,12 @@ import (
var initCmd = &cli.Command{ var initCmd = &cli.Command{
Name: "init", Name: "init",
Usage: "Initialize a lotus storage miner repo", Usage: "Initialize a lotus storage miner repo",
Flags: []cli.Flag{
&cli.StringFlag{
Name: "actor",
Usage: "specify the address of an already created miner actor",
},
},
Action: func(cctx *cli.Context) error { Action: func(cctx *cli.Context) error {
log.Info("Initializing lotus storage miner") log.Info("Initializing lotus storage miner")
log.Info("Checking if repo exists") log.Info("Checking if repo exists")
@ -77,21 +86,119 @@ var initCmd = &cli.Command{
return err return err
} }
var addr address.Address
if act := cctx.String("actor"); act != "" {
a, err := address.NewFromString(act)
if err != nil {
return err
}
if err := configureStorageMiner(ctx, api, a, peerid); err != nil {
return xerrors.Errorf("failed to configure storage miner: %w", err)
}
addr = a
} else {
a, err := createStorageMiner(ctx, api, peerid)
if err != nil {
return err
}
addr = a
}
ds, err := lr.Datastore("/metadata")
if err != nil {
return err
}
if err := ds.Put(datastore.NewKey("miner-address"), addr.Bytes()); err != nil {
return err
}
// TODO: Point to setting storage price, maybe do it interactively or something
log.Info("Storage miner successfully created, you can now start it with 'lotus-storage-miner run'")
return nil
},
}
func configureStorageMiner(ctx context.Context, api api.FullNode, addr address.Address, peerid peer.ID) error {
// This really just needs to be an api call at this point...
recp, err := api.ChainCall(ctx, &types.Message{
To: addr,
From: addr,
Method: actors.MAMethods.GetWorkerAddr,
}, nil)
if err != nil {
return xerrors.Errorf("failed to get worker address: %w", err)
}
if recp.ExitCode != 0 {
return xerrors.Errorf("getWorkerAddr returned exit code %d", recp.ExitCode)
}
waddr, err := address.NewFromBytes(recp.Return)
if err != nil {
return xerrors.Errorf("getWorkerAddr returned bad address: %w", err)
}
enc, err := actors.SerializeParams(&actors.UpdatePeerIDParams{PeerID: peerid})
if err != nil {
return err
}
nonce, err := api.MpoolGetNonce(ctx, waddr)
if err != nil {
return err
}
msg := &types.Message{
To: addr,
From: waddr,
Method: actors.MAMethods.UpdatePeerID,
Params: enc,
Nonce: nonce,
GasPrice: types.NewInt(0),
GasLimit: types.NewInt(1000),
}
smsg, err := api.WalletSignMessage(ctx, waddr, msg)
if err != nil {
return err
}
if err := api.MpoolPush(ctx, smsg); err != nil {
return err
}
ret, err := api.ChainWaitMsg(ctx, smsg.Cid())
if err != nil {
return err
}
if ret.Receipt.ExitCode != 0 {
return xerrors.Errorf("update peer id message failed with exit code %d", ret.Receipt.ExitCode)
}
return nil
}
func createStorageMiner(ctx context.Context, api api.FullNode, peerid peer.ID) (address.Address, error) {
log.Info("Creating StorageMarket.CreateStorageMiner message") log.Info("Creating StorageMarket.CreateStorageMiner message")
defOwner, err := api.WalletDefaultAddress(ctx) defOwner, err := api.WalletDefaultAddress(ctx)
if err != nil { if err != nil {
return err return address.Undef, err
} }
nonce, err := api.MpoolGetNonce(ctx, defOwner) nonce, err := api.MpoolGetNonce(ctx, defOwner)
if err != nil { if err != nil {
return err return address.Undef, err
} }
k, err := api.WalletNew(ctx, types.KTSecp256k1) k, err := api.WalletNew(ctx, types.KTSecp256k1)
if err != nil { if err != nil {
return err return address.Undef, err
} }
collateral := types.NewInt(1000) // TODO: Get this from params collateral := types.NewInt(1000) // TODO: Get this from params
@ -103,7 +210,7 @@ var initCmd = &cli.Command{
PeerID: peerid, PeerID: peerid,
}) })
if err != nil { if err != nil {
return err return address.Undef, err
} }
createStorageMinerMsg := types.Message{ createStorageMinerMsg := types.Message{
@ -120,14 +227,14 @@ var initCmd = &cli.Command{
unsigned, err := createStorageMinerMsg.Serialize() unsigned, err := createStorageMinerMsg.Serialize()
if err != nil { if err != nil {
return err return address.Undef, err
} }
log.Info("Signing StorageMarket.CreateStorageMiner") log.Info("Signing StorageMarket.CreateStorageMiner")
sig, err := api.WalletSign(ctx, defOwner, unsigned) sig, err := api.WalletSign(ctx, defOwner, unsigned)
if err != nil { if err != nil {
return err return address.Undef, err
} }
signed := &types.SignedMessage{ signed := &types.SignedMessage{
@ -139,34 +246,21 @@ var initCmd = &cli.Command{
err = api.MpoolPush(ctx, signed) err = api.MpoolPush(ctx, signed)
if err != nil { if err != nil {
return err return address.Undef, err
} }
log.Infof("Waiting for confirmation") log.Infof("Waiting for confirmation")
mw, err := api.ChainWaitMsg(ctx, signed.Cid()) mw, err := api.ChainWaitMsg(ctx, signed.Cid())
if err != nil { if err != nil {
return err return address.Undef, err
} }
addr, err := address.NewFromBytes(mw.Receipt.Return) addr, err := address.NewFromBytes(mw.Receipt.Return)
if err != nil { if err != nil {
return err return address.Undef, err
} }
log.Infof("New storage miners address is: %s", addr) log.Infof("New storage miners address is: %s", addr)
return addr, nil
ds, err := lr.Datastore("/metadata")
if err != nil {
return err
}
if err := ds.Put(datastore.NewKey("miner-address"), addr.Bytes()); err != nil {
return err
}
// TODO: Point to setting storage price, maybe do it interactively or something
log.Info("Storage miner successfully created, you can now start it with 'lotus-storage-miner run'")
return nil
},
} }