spects-actors: More type propagation
This commit is contained in:
parent
36aed6f871
commit
74bf9119cc
@ -227,9 +227,9 @@ type PaymentInfo struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type VoucherSpec struct {
|
type VoucherSpec struct {
|
||||||
Amount types.BigInt
|
Amount types.BigInt
|
||||||
TimeLock uint64
|
TimeLock abi.ChainEpoch
|
||||||
MinClose uint64
|
MinSettle abi.ChainEpoch
|
||||||
|
|
||||||
Extra *types.ModVerifyParams
|
Extra *types.ModVerifyParams
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
|
"github.com/filecoin-project/specs-actors/actors/builtin"
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
"github.com/filecoin-project/go-address"
|
"github.com/filecoin-project/go-address"
|
||||||
@ -55,13 +56,20 @@ func (fm *FundMgr) EnsureAvailable(ctx context.Context, addr address.Address, am
|
|||||||
|
|
||||||
fm.lk.Unlock()
|
fm.lk.Unlock()
|
||||||
|
|
||||||
|
var err error
|
||||||
|
params, err := actors.SerializeParams(&toAdd)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
smsg, err := fm.mpool.MpoolPushMessage(ctx, &types.Message{
|
smsg, err := fm.mpool.MpoolPushMessage(ctx, &types.Message{
|
||||||
To: actors.StorageMarketAddress,
|
To: actors.StorageMarketAddress,
|
||||||
From: addr,
|
From: addr,
|
||||||
Value: toAdd,
|
Value: toAdd,
|
||||||
GasPrice: types.NewInt(0),
|
GasPrice: types.NewInt(0),
|
||||||
GasLimit: types.NewInt(1000000),
|
GasLimit: types.NewInt(1000000),
|
||||||
Method: actors.SMAMethods.AddBalance,
|
Method: builtin.MethodsMarket.AddBalance,
|
||||||
|
Params: params,
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
@ -6,4 +6,4 @@ import (
|
|||||||
|
|
||||||
type SignedStorageAsk = storagemarket.SignedStorageAsk
|
type SignedStorageAsk = storagemarket.SignedStorageAsk
|
||||||
|
|
||||||
type StorageAsk = storagemarket.StorageAsk
|
type StorageAsk = storagemarket.StorageAsk
|
||||||
|
@ -2,8 +2,6 @@ package types
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/filecoin-project/specs-actors/actors/crypto"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -13,7 +11,7 @@ var (
|
|||||||
|
|
||||||
// KeyInfo is used for storing keys in KeyStore
|
// KeyInfo is used for storing keys in KeyStore
|
||||||
type KeyInfo struct {
|
type KeyInfo struct {
|
||||||
Type crypto.SigType
|
Type string
|
||||||
PrivateKey []byte
|
PrivateKey []byte
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,6 +24,8 @@ var log = logging.Logger("wallet")
|
|||||||
const (
|
const (
|
||||||
KNamePrefix = "wallet-"
|
KNamePrefix = "wallet-"
|
||||||
KDefault = "default"
|
KDefault = "default"
|
||||||
|
KTBLS = "bls"
|
||||||
|
KTSecp256k1 = "secp256k1"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Wallet struct {
|
type Wallet struct {
|
||||||
@ -62,7 +64,7 @@ func (w *Wallet) Sign(ctx context.Context, addr address.Address, msg []byte) (*c
|
|||||||
return nil, xerrors.Errorf("signing using key '%s': %w", addr.String(), types.ErrKeyInfoNotFound)
|
return nil, xerrors.Errorf("signing using key '%s': %w", addr.String(), types.ErrKeyInfoNotFound)
|
||||||
}
|
}
|
||||||
|
|
||||||
return sigs.Sign(ki.Type, ki.PrivateKey, msg)
|
return sigs.Sign(ActSigType(ki.Type), ki.PrivateKey, msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *Wallet) findKey(addr address.Address) (*Key, error) {
|
func (w *Wallet) findKey(addr address.Address) (*Key, error) {
|
||||||
@ -186,7 +188,7 @@ func GenerateKey(typ crypto.SigType) (*Key, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
ki := types.KeyInfo{
|
ki := types.KeyInfo{
|
||||||
Type: typ,
|
Type: kstoreSigType(typ),
|
||||||
PrivateKey: pk,
|
PrivateKey: pk,
|
||||||
}
|
}
|
||||||
return NewKey(ki)
|
return NewKey(ki)
|
||||||
@ -241,18 +243,18 @@ func NewKey(keyinfo types.KeyInfo) (*Key, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var err error
|
var err error
|
||||||
k.PublicKey, err = sigs.ToPublic(k.Type, k.PrivateKey)
|
k.PublicKey, err = sigs.ToPublic(ActSigType(k.Type), k.PrivateKey)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
switch k.Type {
|
switch k.Type {
|
||||||
case crypto.SigTypeSecp256k1:
|
case KTSecp256k1:
|
||||||
k.Address, err = address.NewSecp256k1Address(k.PublicKey)
|
k.Address, err = address.NewSecp256k1Address(k.PublicKey)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, xerrors.Errorf("converting Secp256k1 to address: %w", err)
|
return nil, xerrors.Errorf("converting Secp256k1 to address: %w", err)
|
||||||
}
|
}
|
||||||
case crypto.SigTypeBLS:
|
case KTBLS:
|
||||||
k.Address, err = address.NewBLSAddress(k.PublicKey)
|
k.Address, err = address.NewBLSAddress(k.PublicKey)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, xerrors.Errorf("converting BLS to address: %w", err)
|
return nil, xerrors.Errorf("converting BLS to address: %w", err)
|
||||||
@ -263,3 +265,25 @@ func NewKey(keyinfo types.KeyInfo) (*Key, error) {
|
|||||||
return k, nil
|
return k, nil
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func kstoreSigType(typ crypto.SigType) string {
|
||||||
|
switch typ {
|
||||||
|
case crypto.SigTypeBLS:
|
||||||
|
return KTBLS
|
||||||
|
case crypto.SigTypeSecp256k1:
|
||||||
|
return KTSecp256k1
|
||||||
|
default:
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func ActSigType(typ string) crypto.SigType {
|
||||||
|
switch typ {
|
||||||
|
case KTBLS:
|
||||||
|
return crypto.SigTypeBLS
|
||||||
|
case KTSecp256k1:
|
||||||
|
return crypto.SigTypeSecp256k1
|
||||||
|
default:
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
25
cli/chain.go
25
cli/chain.go
@ -11,7 +11,11 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/filecoin-project/go-address"
|
||||||
|
cborutil "github.com/filecoin-project/go-cbor-util"
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
|
"github.com/filecoin-project/specs-actors/actors/builtin"
|
||||||
|
"github.com/filecoin-project/specs-actors/actors/builtin/power"
|
||||||
cid "github.com/ipfs/go-cid"
|
cid "github.com/ipfs/go-cid"
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
"gopkg.in/urfave/cli.v2"
|
"gopkg.in/urfave/cli.v2"
|
||||||
@ -595,9 +599,22 @@ var slashConsensusFault = &cli.Command{
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
params, err := actors.SerializeParams(&actors.ArbitrateConsensusFaultParams{
|
bh1, err := cborutil.Dump(b1)
|
||||||
Block1: b1,
|
if err != nil {
|
||||||
Block2: b2,
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
bh2, err := cborutil.Dump(b2)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
params, err := actors.SerializeParams(&power.ReportConsensusFaultParams{
|
||||||
|
BlockHeader1: bh1,
|
||||||
|
BlockHeader2: bh2,
|
||||||
|
Target: address.Address{},
|
||||||
|
FaultEpoch: 0,
|
||||||
|
FaultType: 0,
|
||||||
})
|
})
|
||||||
|
|
||||||
msg := &types.Message{
|
msg := &types.Message{
|
||||||
@ -606,7 +623,7 @@ var slashConsensusFault = &cli.Command{
|
|||||||
Value: types.NewInt(0),
|
Value: types.NewInt(0),
|
||||||
GasPrice: types.NewInt(1),
|
GasPrice: types.NewInt(1),
|
||||||
GasLimit: types.NewInt(10000000),
|
GasLimit: types.NewInt(10000000),
|
||||||
Method: actors.SPAMethods.ArbitrateConsensusFault,
|
Method: builtin.MethodsPower.ReportConsensusFault,
|
||||||
Params: params,
|
Params: params,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ import (
|
|||||||
|
|
||||||
"github.com/filecoin-project/go-address"
|
"github.com/filecoin-project/go-address"
|
||||||
"github.com/filecoin-project/go-fil-markets/storagemarket"
|
"github.com/filecoin-project/go-fil-markets/storagemarket"
|
||||||
actors "github.com/filecoin-project/lotus/chain/actors"
|
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -291,27 +291,15 @@ var clientQueryAskCmd = &cli.Command{
|
|||||||
}
|
}
|
||||||
pid = p
|
pid = p
|
||||||
} else {
|
} else {
|
||||||
ret, err := api.StateCall(ctx, &types.Message{
|
p, err := api.StateMinerPeerID(ctx, maddr, nil)
|
||||||
To: maddr,
|
|
||||||
From: maddr,
|
|
||||||
Method: actors.MAMethods.GetPeerID,
|
|
||||||
}, nil)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("failed to get peerID for miner: %w", err)
|
return xerrors.Errorf("failed to get peerID for miner: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if ret.ExitCode != 0 {
|
if p == peer.ID("SETME") {
|
||||||
return fmt.Errorf("call to GetPeerID was unsuccesful (exit code %d)", ret.ExitCode)
|
|
||||||
}
|
|
||||||
if peer.ID(ret.Return) == peer.ID("SETME") {
|
|
||||||
return fmt.Errorf("the miner hasn't initialized yet")
|
return fmt.Errorf("the miner hasn't initialized yet")
|
||||||
}
|
}
|
||||||
|
|
||||||
p, err := peer.IDFromBytes(ret.Return)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
pid = p
|
pid = p
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14,6 +14,7 @@ import (
|
|||||||
"github.com/filecoin-project/go-address"
|
"github.com/filecoin-project/go-address"
|
||||||
"github.com/filecoin-project/specs-actors/actors/abi"
|
"github.com/filecoin-project/specs-actors/actors/abi"
|
||||||
"github.com/filecoin-project/specs-actors/actors/builtin"
|
"github.com/filecoin-project/specs-actors/actors/builtin"
|
||||||
|
init_ "github.com/filecoin-project/specs-actors/actors/builtin/init"
|
||||||
samsig "github.com/filecoin-project/specs-actors/actors/builtin/multisig"
|
samsig "github.com/filecoin-project/specs-actors/actors/builtin/multisig"
|
||||||
cid "github.com/ipfs/go-cid"
|
cid "github.com/ipfs/go-cid"
|
||||||
"github.com/ipfs/go-hamt-ipld"
|
"github.com/ipfs/go-hamt-ipld"
|
||||||
@ -104,9 +105,9 @@ var msigCreateCmd = &cli.Command{
|
|||||||
}
|
}
|
||||||
|
|
||||||
// new actors are created by invoking 'exec' on the init actor with the constructor params
|
// new actors are created by invoking 'exec' on the init actor with the constructor params
|
||||||
execParams := &actors.ExecParams{
|
execParams := &init_.ExecParams{
|
||||||
Code: actors.MultisigCodeCid,
|
CodeCID: actors.MultisigCodeCid,
|
||||||
Params: enc,
|
ConstructorParams: enc,
|
||||||
}
|
}
|
||||||
|
|
||||||
enc, err = actors.SerializeParams(execParams)
|
enc, err = actors.SerializeParams(execParams)
|
||||||
@ -118,7 +119,7 @@ var msigCreateCmd = &cli.Command{
|
|||||||
msg := types.Message{
|
msg := types.Message{
|
||||||
To: actors.InitAddress,
|
To: actors.InitAddress,
|
||||||
From: sendAddr,
|
From: sendAddr,
|
||||||
Method: actors.IAMethods.Exec,
|
Method: builtin.MethodsInit.Exec,
|
||||||
Params: enc,
|
Params: enc,
|
||||||
GasPrice: types.NewInt(1),
|
GasPrice: types.NewInt(1),
|
||||||
GasLimit: types.NewInt(1000000),
|
GasLimit: types.NewInt(1000000),
|
||||||
@ -347,7 +348,7 @@ var msigProposeCmd = &cli.Command{
|
|||||||
To: msig,
|
To: msig,
|
||||||
From: from,
|
From: from,
|
||||||
Value: types.NewInt(0),
|
Value: types.NewInt(0),
|
||||||
Method: uint64(builtin.MethodsMultisig.Propose),
|
Method: builtin.MethodsMultisig.Propose,
|
||||||
Params: enc,
|
Params: enc,
|
||||||
GasLimit: types.NewInt(100000),
|
GasLimit: types.NewInt(100000),
|
||||||
GasPrice: types.NewInt(1),
|
GasPrice: types.NewInt(1),
|
||||||
@ -432,7 +433,7 @@ var msigApproveCmd = &cli.Command{
|
|||||||
To: msig,
|
To: msig,
|
||||||
From: from,
|
From: from,
|
||||||
Value: types.NewInt(0),
|
Value: types.NewInt(0),
|
||||||
Method: uint64(builtin.MethodsMultisig.Approve),
|
Method: builtin.MethodsMultisig.Approve,
|
||||||
Params: enc,
|
Params: enc,
|
||||||
GasLimit: types.NewInt(100000),
|
GasLimit: types.NewInt(100000),
|
||||||
GasPrice: types.NewInt(1),
|
GasPrice: types.NewInt(1),
|
||||||
|
21
cli/paych.go
21
cli/paych.go
@ -1,11 +1,15 @@
|
|||||||
package cli
|
package cli
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
|
"encoding/base64"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/filecoin-project/go-address"
|
"github.com/filecoin-project/go-address"
|
||||||
types "github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/specs-actors/actors/builtin/paych"
|
||||||
"gopkg.in/urfave/cli.v2"
|
"gopkg.in/urfave/cli.v2"
|
||||||
|
|
||||||
|
types "github.com/filecoin-project/lotus/chain/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
var paychCmd = &cli.Command{
|
var paychCmd = &cli.Command{
|
||||||
@ -136,7 +140,7 @@ var paychVoucherCreateCmd = &cli.Command{
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
enc, err := sv.EncodedString()
|
enc, err := EncodedString(sv)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -250,7 +254,7 @@ var paychVoucherListCmd = &cli.Command{
|
|||||||
|
|
||||||
for _, v := range vouchers {
|
for _, v := range vouchers {
|
||||||
if cctx.Bool("export") {
|
if cctx.Bool("export") {
|
||||||
enc, err := v.EncodedString()
|
enc, err := EncodedString(v)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -308,7 +312,7 @@ var paychVoucherBestSpendableCmd = &cli.Command{
|
|||||||
return fmt.Errorf("No spendable vouchers for that channel")
|
return fmt.Errorf("No spendable vouchers for that channel")
|
||||||
}
|
}
|
||||||
|
|
||||||
enc, err := best.EncodedString()
|
enc, err := EncodedString(best)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -364,3 +368,12 @@ var paychVoucherSubmitCmd = &cli.Command{
|
|||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func EncodedString(sv *paych.SignedVoucher) (string, error) {
|
||||||
|
buf := new(bytes.Buffer)
|
||||||
|
if err := sv.MarshalCBOR(buf); err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
return base64.RawURLEncoding.EncodeToString(buf.Bytes()), nil
|
||||||
|
}
|
||||||
|
@ -721,7 +721,7 @@ var stateCallCmd = &cli.Command{
|
|||||||
&cli.StringFlag{
|
&cli.StringFlag{
|
||||||
Name: "from",
|
Name: "from",
|
||||||
Usage: "",
|
Usage: "",
|
||||||
Value: actors.NetworkAddress.String(),
|
Value: actors.SystemAddress.String(),
|
||||||
},
|
},
|
||||||
&cli.StringFlag{
|
&cli.StringFlag{
|
||||||
Name: "value",
|
Name: "value",
|
||||||
@ -788,7 +788,7 @@ var stateCallCmd = &cli.Command{
|
|||||||
Value: types.BigInt(value),
|
Value: types.BigInt(value),
|
||||||
GasLimit: types.NewInt(10000000000),
|
GasLimit: types.NewInt(10000000000),
|
||||||
GasPrice: types.NewInt(0),
|
GasPrice: types.NewInt(0),
|
||||||
Method: method,
|
Method: abi.MethodNum(method),
|
||||||
Params: params,
|
Params: params,
|
||||||
}, ts)
|
}, ts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -10,6 +10,8 @@ import (
|
|||||||
|
|
||||||
"github.com/filecoin-project/go-address"
|
"github.com/filecoin-project/go-address"
|
||||||
types "github.com/filecoin-project/lotus/chain/types"
|
types "github.com/filecoin-project/lotus/chain/types"
|
||||||
|
"github.com/filecoin-project/lotus/chain/wallet"
|
||||||
|
|
||||||
"gopkg.in/urfave/cli.v2"
|
"gopkg.in/urfave/cli.v2"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -44,7 +46,7 @@ var walletNew = &cli.Command{
|
|||||||
t = "secp256k1"
|
t = "secp256k1"
|
||||||
}
|
}
|
||||||
|
|
||||||
nk, err := api.WalletNew(ctx, t)
|
nk, err := api.WalletNew(ctx, wallet.ActSigType(t))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
1
go.mod
1
go.mod
@ -85,6 +85,7 @@ require (
|
|||||||
github.com/multiformats/go-varint v0.0.5
|
github.com/multiformats/go-varint v0.0.5
|
||||||
github.com/opentracing/opentracing-go v1.1.0
|
github.com/opentracing/opentracing-go v1.1.0
|
||||||
github.com/prometheus/common v0.4.0
|
github.com/prometheus/common v0.4.0
|
||||||
|
github.com/rogpeppe/go-internal v1.3.0
|
||||||
github.com/stretchr/testify v1.4.0
|
github.com/stretchr/testify v1.4.0
|
||||||
github.com/whyrusleeping/bencher v0.0.0-20190829221104-bb6607aa8bba
|
github.com/whyrusleeping/bencher v0.0.0-20190829221104-bb6607aa8bba
|
||||||
github.com/whyrusleeping/cbor-gen v0.0.0-20200213013405-80352c7ae952
|
github.com/whyrusleeping/cbor-gen v0.0.0-20200213013405-80352c7ae952
|
||||||
|
1
go.sum
1
go.sum
@ -691,6 +691,7 @@ github.com/prometheus/common v0.4.0/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y8
|
|||||||
github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
|
github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
|
||||||
github.com/prometheus/procfs v0.0.0-20190117184657-bf6a532e95b1/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
|
github.com/prometheus/procfs v0.0.0-20190117184657-bf6a532e95b1/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
|
||||||
github.com/rcrowley/go-metrics v0.0.0-20181016184325-3113b8401b8a/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4=
|
github.com/rcrowley/go-metrics v0.0.0-20181016184325-3113b8401b8a/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4=
|
||||||
|
github.com/rogpeppe/go-internal v1.3.0 h1:RR9dF3JtopPvtkroDZuVD7qquD0bnHlKSqaQhgwt8yk=
|
||||||
github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4=
|
github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4=
|
||||||
github.com/russross/blackfriday v1.5.2 h1:HyvC0ARfnZBqnXwABFeSZHpKvJHJJfPz81GNueLj0oo=
|
github.com/russross/blackfriday v1.5.2 h1:HyvC0ARfnZBqnXwABFeSZHpKvJHJJfPz81GNueLj0oo=
|
||||||
github.com/russross/blackfriday v1.5.2/go.mod h1:JO/DiYxRf+HjHt06OyowR9PTA263kcR/rfWxYHBV53g=
|
github.com/russross/blackfriday v1.5.2/go.mod h1:JO/DiYxRf+HjHt06OyowR9PTA263kcR/rfWxYHBV53g=
|
||||||
|
@ -4,6 +4,8 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
|
"github.com/filecoin-project/specs-actors/actors/builtin"
|
||||||
|
"github.com/filecoin-project/specs-actors/actors/builtin/paych"
|
||||||
"github.com/ipfs/go-cid"
|
"github.com/ipfs/go-cid"
|
||||||
"go.uber.org/fx"
|
"go.uber.org/fx"
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
@ -64,9 +66,9 @@ func (a *PaychAPI) PaychNewPayment(ctx context.Context, from, to address.Address
|
|||||||
Amount: v.Amount,
|
Amount: v.Amount,
|
||||||
Lane: lane,
|
Lane: lane,
|
||||||
|
|
||||||
Extra: v.Extra,
|
Extra: v.Extra,
|
||||||
TimeLock: v.TimeLock,
|
TimeLock: v.TimeLock,
|
||||||
MinCloseHeight: v.MinClose,
|
MinSettleHeight: v.MinSettle,
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -103,6 +105,8 @@ func (a *PaychAPI) PaychStatus(ctx context.Context, pch address.Address) (*api.P
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (a *PaychAPI) PaychClose(ctx context.Context, addr address.Address) (cid.Cid, error) {
|
func (a *PaychAPI) PaychClose(ctx context.Context, addr address.Address) (cid.Cid, error) {
|
||||||
|
panic("TODO Settle logic")
|
||||||
|
|
||||||
ci, err := a.PaychMgr.GetChannelInfo(addr)
|
ci, err := a.PaychMgr.GetChannelInfo(addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return cid.Undef, err
|
return cid.Undef, err
|
||||||
@ -117,7 +121,7 @@ func (a *PaychAPI) PaychClose(ctx context.Context, addr address.Address) (cid.Ci
|
|||||||
To: addr,
|
To: addr,
|
||||||
From: ci.Control,
|
From: ci.Control,
|
||||||
Value: types.NewInt(0),
|
Value: types.NewInt(0),
|
||||||
Method: actors.PCAMethods.Close,
|
Method: builtin.MethodsPaych.Settle,
|
||||||
Nonce: nonce,
|
Nonce: nonce,
|
||||||
|
|
||||||
GasLimit: types.NewInt(500),
|
GasLimit: types.NewInt(500),
|
||||||
@ -221,7 +225,7 @@ func (a *PaychAPI) PaychVoucherSubmit(ctx context.Context, ch address.Address, s
|
|||||||
return cid.Undef, fmt.Errorf("cant handle more advanced payment channel stuff yet")
|
return cid.Undef, fmt.Errorf("cant handle more advanced payment channel stuff yet")
|
||||||
}
|
}
|
||||||
|
|
||||||
enc, err := actors.SerializeParams(&actors.PCAUpdateChannelStateParams{
|
enc, err := actors.SerializeParams(&paych.UpdateChannelStateParams{
|
||||||
Sv: *sv,
|
Sv: *sv,
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -233,7 +237,7 @@ func (a *PaychAPI) PaychVoucherSubmit(ctx context.Context, ch address.Address, s
|
|||||||
To: ch,
|
To: ch,
|
||||||
Value: types.NewInt(0),
|
Value: types.NewInt(0),
|
||||||
Nonce: nonce,
|
Nonce: nonce,
|
||||||
Method: actors.PCAMethods.UpdateChannelState,
|
Method: builtin.MethodsPaych.UpdateChannelState,
|
||||||
Params: enc,
|
Params: enc,
|
||||||
GasLimit: types.NewInt(100000),
|
GasLimit: types.NewInt(100000),
|
||||||
GasPrice: types.NewInt(0),
|
GasPrice: types.NewInt(0),
|
||||||
|
@ -229,7 +229,7 @@ func (s *FPoStScheduler) submitPost(ctx context.Context, proof *actors.SubmitFal
|
|||||||
msg := &types.Message{
|
msg := &types.Message{
|
||||||
To: s.actor,
|
To: s.actor,
|
||||||
From: s.worker,
|
From: s.worker,
|
||||||
Method: actors.MAMethods.SubmitFallbackPoSt,
|
Method: builtin.MethodsMiner.SubmitFallbackPoSt,
|
||||||
Params: enc,
|
Params: enc,
|
||||||
Value: types.NewInt(1000), // currently hard-coded late fee in actor, returned if not late
|
Value: types.NewInt(1000), // currently hard-coded late fee in actor, returned if not late
|
||||||
GasLimit: types.NewInt(10000000), // i dont know help
|
GasLimit: types.NewInt(10000000), // i dont know help
|
||||||
|
@ -61,6 +61,7 @@ type storageMinerApi interface {
|
|||||||
ChainGetTipSetByHeight(context.Context, abi.ChainEpoch, *types.TipSet) (*types.TipSet, error)
|
ChainGetTipSetByHeight(context.Context, abi.ChainEpoch, *types.TipSet) (*types.TipSet, error)
|
||||||
ChainGetBlockMessages(context.Context, cid.Cid) (*api.BlockMessages, error)
|
ChainGetBlockMessages(context.Context, cid.Cid) (*api.BlockMessages, error)
|
||||||
ChainReadObj(context.Context, cid.Cid) ([]byte, error)
|
ChainReadObj(context.Context, cid.Cid) ([]byte, error)
|
||||||
|
ChainHasObj(context.Context, cid.Cid) (bool, error)
|
||||||
|
|
||||||
WalletSign(context.Context, address.Address, []byte) (*types.Signature, error)
|
WalletSign(context.Context, address.Address, []byte) (*types.Signature, error)
|
||||||
WalletBalance(context.Context, address.Address) (types.BigInt, error)
|
WalletBalance(context.Context, address.Address) (types.BigInt, error)
|
||||||
|
Loading…
Reference in New Issue
Block a user