lnwallet: add node's ID to reservation workflow

This commit is contained in:
Olaoluwa Osuntokun 2015-12-26 00:05:07 -06:00
parent 4bb526854a
commit ff92efe7df
2 changed files with 28 additions and 14 deletions

@ -1,7 +1,6 @@
package lnwallet package lnwallet
import ( import (
"bytes"
"errors" "errors"
"fmt" "fmt"
"math" "math"
@ -64,6 +63,8 @@ type initFundingReserveMsg struct {
fundingType FundingType fundingType FundingType
minFeeRate btcutil.Amount minFeeRate btcutil.Amount
nodeID [32]byte
// TODO(roasbeef): optional reserve for CLTV, etc. // TODO(roasbeef): optional reserve for CLTV, etc.
// Insuffcient funds etc.. // Insuffcient funds etc..
@ -290,13 +291,14 @@ out:
// * ourCommitKey // * ourCommitKey
// * ourDeliveryAddress // * ourDeliveryAddress
// * ourShaChain // * ourShaChain
func (l *LightningWallet) InitChannelReservation(a btcutil.Amount, t FundingType) (*ChannelReservation, error) { func (l *LightningWallet) InitChannelReservation(a btcutil.Amount, t FundingType, theirID [32]byte) (*ChannelReservation, error) {
errChan := make(chan error, 1) errChan := make(chan error, 1)
respChan := make(chan *ChannelReservation, 1) respChan := make(chan *ChannelReservation, 1)
l.msgChan <- &initFundingReserveMsg{ l.msgChan <- &initFundingReserveMsg{
fundingAmount: a, fundingAmount: a,
fundingType: t, fundingType: t,
nodeID: theirID,
err: errChan, err: errChan,
resp: respChan, resp: respChan,
} }
@ -320,6 +322,7 @@ func (l *LightningWallet) handleFundingReserveRequest(req *initFundingReserveMsg
reservation.Lock() reservation.Lock()
defer reservation.Unlock() defer reservation.Unlock()
reservation.partialState.TheirLNID = req.nodeID
ourContribution := reservation.ourContribution ourContribution := reservation.ourContribution
// Find all unlocked unspent outputs with greater than 6 confirmations. // Find all unlocked unspent outputs with greater than 6 confirmations.

@ -3,7 +3,6 @@ package lnwallet
import ( import (
"bytes" "bytes"
"crypto/sha256" "crypto/sha256"
"fmt"
"io/ioutil" "io/ioutil"
"os" "os"
"testing" "testing"
@ -39,7 +38,7 @@ var (
} }
// Use a hard-coded HD seed. // Use a hard-coded HD seed.
testHdSeed = []byte{ testHdSeed = [32]byte{
0xb7, 0x94, 0x38, 0x5f, 0x2d, 0x1e, 0xf7, 0xab, 0xb7, 0x94, 0x38, 0x5f, 0x2d, 0x1e, 0xf7, 0xab,
0x4d, 0x92, 0x73, 0xd1, 0x90, 0x63, 0x81, 0xb4, 0x4d, 0x92, 0x73, 0xd1, 0x90, 0x63, 0x81, 0xb4,
0x4f, 0x2f, 0x6f, 0x25, 0x88, 0xa3, 0xef, 0xb9, 0x4f, 0x2f, 0x6f, 0x25, 0x88, 0xa3, 0xef, 0xb9,
@ -68,7 +67,8 @@ type bobNode struct {
channelKey *btcec.PublicKey channelKey *btcec.PublicKey
deliveryAddress btcutil.Address deliveryAddress btcutil.Address
revocation [wire.HashSize]byte revocation [wire.HashSize]byte
delay int64 delay uint32
id [wire.HashSize]byte
availableOutputs []*wire.TxIn availableOutputs []*wire.TxIn
changeOutputs []*wire.TxOut changeOutputs []*wire.TxOut
@ -143,7 +143,12 @@ func newBobNode() (*bobNode, error) {
copy(revocation[:], bobsPrivKey) copy(revocation[:], bobsPrivKey)
revocation[0] = 0xff revocation[0] = 0xff
// His ID is just as creative...
var id [wire.HashSize]byte
id[0] = 0xff
return &bobNode{ return &bobNode{
id: id,
privKey: privKey, privKey: privKey,
channelKey: pubKey, channelKey: pubKey,
deliveryAddress: bobAddr, deliveryAddress: bobAddr,
@ -279,7 +284,7 @@ func createTestWallet() (string, *LightningWallet, error) {
return "", nil, nil return "", nil, nil
} }
wallet, err := NewLightningWallet(privPass, nil, testHdSeed, tempTestDir) wallet, err := NewLightningWallet(privPass, nil, testHdSeed[:], tempTestDir)
if err != nil { if err != nil {
return "", nil, err return "", nil, err
} }
@ -305,8 +310,8 @@ func testBasicWalletReservationWorkFlow(lnwallet *LightningWallet, t *testing.T)
fundingAmount := btcutil.Amount(5 * 1e8) fundingAmount := btcutil.Amount(5 * 1e8)
fmt.Println("init res") fmt.Println("init res")
// TODO(roasbeef): include csv delay? // TODO(roasbeef): include csv delay?
chanReservation, err := lnwallet.InitChannelReservation(fundingAmount, SIGHASH) chanReservation, err := lnwallet.InitChannelReservation(fundingAmount,
fmt.Println("fail init res") SIGHASH, bobNode.id)
if err != nil { if err != nil {
t.Fatalf("unable to initialize funding reservation: %v", err) t.Fatalf("unable to initialize funding reservation: %v", err)
} }
@ -474,11 +479,13 @@ func testFundingTransactionLockedOutputs(lnwallet *LightningWallet, t *testing.T
// TODO(roasbeef): tests for concurrent funding. // TODO(roasbeef): tests for concurrent funding.
// * also func for below // * also func for below
fundingAmount := btcutil.Amount(8 * 1e8) fundingAmount := btcutil.Amount(8 * 1e8)
chanReservation1, err := lnwallet.InitChannelReservation(fundingAmount, SIGHASH) chanReservation1, err := lnwallet.InitChannelReservation(fundingAmount,
SIGHASH, testHdSeed)
if err != nil { if err != nil {
t.Fatalf("unable to initialize funding reservation 1: %v", err) t.Fatalf("unable to initialize funding reservation 1: %v", err)
} }
chanReservation2, err := lnwallet.InitChannelReservation(fundingAmount, SIGHASH) chanReservation2, err := lnwallet.InitChannelReservation(fundingAmount,
SIGHASH, testHdSeed)
if err != nil { if err != nil {
t.Fatalf("unable to initialize funding reservation 2: %v", err) t.Fatalf("unable to initialize funding reservation 2: %v", err)
} }
@ -508,7 +515,8 @@ func testFundingTransactionLockedOutputs(lnwallet *LightningWallet, t *testing.T
// 5 BTC. We only have 4BTC worth of outpoints that aren't locked, so // 5 BTC. We only have 4BTC worth of outpoints that aren't locked, so
// this should fail. // this should fail.
amt := btcutil.Amount(8 * 1e8) amt := btcutil.Amount(8 * 1e8)
failedReservation, err := lnwallet.InitChannelReservation(amt, SIGHASH) failedReservation, err := lnwallet.InitChannelReservation(amt,
SIGHASH, testHdSeed)
if err == nil { if err == nil {
t.Fatalf("not error returned, should fail on coin selection") t.Fatalf("not error returned, should fail on coin selection")
} }
@ -523,7 +531,8 @@ func testFundingTransactionLockedOutputs(lnwallet *LightningWallet, t *testing.T
func testFundingCancellationNotEnoughFunds(lnwallet *LightningWallet, t *testing.T) { func testFundingCancellationNotEnoughFunds(lnwallet *LightningWallet, t *testing.T) {
// Create a reservation for 12 BTC. // Create a reservation for 12 BTC.
fundingAmount := btcutil.Amount(12 * 1e8) fundingAmount := btcutil.Amount(12 * 1e8)
chanReservation, err := lnwallet.InitChannelReservation(fundingAmount, SIGHASH) chanReservation, err := lnwallet.InitChannelReservation(fundingAmount,
SIGHASH, testHdSeed)
if err != nil { if err != nil {
t.Fatalf("unable to initialize funding reservation: %v", err) t.Fatalf("unable to initialize funding reservation: %v", err)
} }
@ -536,7 +545,8 @@ func testFundingCancellationNotEnoughFunds(lnwallet *LightningWallet, t *testing
} }
// Attempt to create another channel with 12 BTC, this should fail. // Attempt to create another channel with 12 BTC, this should fail.
failedReservation, err := lnwallet.InitChannelReservation(fundingAmount, SIGHASH) failedReservation, err := lnwallet.InitChannelReservation(fundingAmount,
SIGHASH, testHdSeed)
if err != coinset.ErrCoinsNoSelectionAvailable { if err != coinset.ErrCoinsNoSelectionAvailable {
t.Fatalf("coin selection succeded should have insufficient funds: %+v", t.Fatalf("coin selection succeded should have insufficient funds: %+v",
failedReservation) failedReservation)
@ -564,7 +574,8 @@ func testFundingCancellationNotEnoughFunds(lnwallet *LightningWallet, t *testing
// attempting coin selection. // attempting coin selection.
// Request to fund a new channel should now succeeed. // Request to fund a new channel should now succeeed.
_, err = lnwallet.InitChannelReservation(fundingAmount, SIGHASH) _, err = lnwallet.InitChannelReservation(fundingAmount,
SIGHASH, testHdSeed)
if err != nil { if err != nil {
t.Fatalf("unable to initialize funding reservation: %v", err) t.Fatalf("unable to initialize funding reservation: %v", err)
} }