set up lotus-storage-miner to be able to use an existing miner actor
This commit is contained in:
parent
d9eaca5527
commit
b271e5231a
@ -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
|
||||||
|
@ -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
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user