funding: modify ChainNotifier usage due to recent API change

This commit is contained in:
Olaoluwa Osuntokun 2017-05-10 17:23:47 -07:00
parent d9e2d7d22c
commit 77cf7ed085
No known key found for this signature in database
GPG Key ID: 9CC5B105D03521A2

@ -141,6 +141,11 @@ type fundingConfig struct {
// so that the channel creation process can be completed. // so that the channel creation process can be completed.
Notifier chainntnfs.ChainNotifier Notifier chainntnfs.ChainNotifier
// ChainIO is used by the FundingManager to determine the current
// height so it's able to reduce the search space for certain
// ChainNotifier implementations when registering for confirmations.
ChainIO lnwallet.BlockChainIO
// SignMessage signs an arbitrary method with a given public key. The // SignMessage signs an arbitrary method with a given public key. The
// actual digest signed is the double sha-256 of the message. In the // actual digest signed is the double sha-256 of the message. In the
// case that the private key corresponding to the passed public key // case that the private key corresponding to the passed public key
@ -253,11 +258,18 @@ func (f *fundingManager) Start() error {
// channels that were waiting for their funding transactions to be // channels that were waiting for their funding transactions to be
// confirmed on the blockchain at the time when the daemon last went // confirmed on the blockchain at the time when the daemon last went
// down. // down.
// TODO(roasbeef): store height that funding finished?
// * would then replace call below
pendingChannels, err := f.cfg.Wallet.ChannelDB.FetchPendingChannels() pendingChannels, err := f.cfg.Wallet.ChannelDB.FetchPendingChannels()
if err != nil { if err != nil {
return err return err
} }
_, currentHeight, err := f.cfg.ChainIO.GetBestBlock()
if err != nil {
return err
}
// For any channels that were in a pending state when the daemon was // For any channels that were in a pending state when the daemon was
// last connected, the Funding Manager will re-initialize the channel // last connected, the Funding Manager will re-initialize the channel
// barriers and will also launch waitForFundingConfirmation to wait for // barriers and will also launch waitForFundingConfirmation to wait for
@ -271,7 +283,7 @@ func (f *fundingManager) Start() error {
f.barrierMtx.Unlock() f.barrierMtx.Unlock()
doneChan := make(chan struct{}) doneChan := make(chan struct{})
go f.waitForFundingConfirmation(channel, doneChan) go f.waitForFundingConfirmation(channel, uint32(currentHeight), doneChan)
} }
f.wg.Add(1) // TODO(roasbeef): tune f.wg.Add(1) // TODO(roasbeef): tune
@ -505,7 +517,7 @@ func (f *fundingManager) handleFundingRequest(fmsg *fundingRequestMsg) {
delay := msg.CsvDelay delay := msg.CsvDelay
// TODO(roasbeef): error if funding flow already ongoing // TODO(roasbeef): error if funding flow already ongoing
fndgLog.Infof("Recv'd fundingRequest(amt=%v, delay=%v, pendingId=%x) "+ fndgLog.Infof("Recv'd fundingRequest(amt=%v, push=%v, delay=%v, pendingId=%x) "+
"from peer(%x)", amt, msg.PushSatoshis, delay, msg.PendingChannelID, "from peer(%x)", amt, msg.PushSatoshis, delay, msg.PendingChannelID,
fmsg.peerAddress.IdentityKey.SerializeCompressed()) fmsg.peerAddress.IdentityKey.SerializeCompressed())
@ -787,9 +799,15 @@ func (f *fundingManager) handleFundingComplete(fmsg *fundingCompleteMsg) {
return return
} }
_, bestHeight, err := f.cfg.ChainIO.GetBestBlock()
if err != nil {
fndgLog.Errorf("unable to get best height: %v", err)
}
go func() { go func() {
doneChan := make(chan struct{}) doneChan := make(chan struct{})
go f.waitForFundingConfirmation(completeChan, doneChan) go f.waitForFundingConfirmation(completeChan,
uint32(bestHeight), doneChan)
<-doneChan <-doneChan
f.deleteReservationCtx(peerKey, fmsg.msg.PendingChannelID) f.deleteReservationCtx(peerKey, fmsg.msg.PendingChannelID)
@ -851,9 +869,15 @@ func (f *fundingManager) handleFundingSignComplete(fmsg *fundingSignCompleteMsg)
}, },
} }
_, bestHeight, err := f.cfg.ChainIO.GetBestBlock()
if err != nil {
fndgLog.Errorf("unable to get best height: %v", err)
}
go func() { go func() {
doneChan := make(chan struct{}) doneChan := make(chan struct{})
go f.waitForFundingConfirmation(completeChan, doneChan) go f.waitForFundingConfirmation(completeChan, uint32(bestHeight),
doneChan)
select { select {
case <-f.quit: case <-f.quit:
@ -885,7 +909,7 @@ func (f *fundingManager) handleFundingSignComplete(fmsg *fundingSignCompleteMsg)
// confirmation, and then to notify the other systems that must be notified // confirmation, and then to notify the other systems that must be notified
// when a channel has become active for lightning transactions. // when a channel has become active for lightning transactions.
func (f *fundingManager) waitForFundingConfirmation(completeChan *channeldb.OpenChannel, func (f *fundingManager) waitForFundingConfirmation(completeChan *channeldb.OpenChannel,
doneChan chan struct{}) { bestHeight uint32, doneChan chan struct{}) {
defer close(doneChan) defer close(doneChan)
@ -893,7 +917,8 @@ func (f *fundingManager) waitForFundingConfirmation(completeChan *channeldb.Open
// transaction reaches `numConfs` confirmations. // transaction reaches `numConfs` confirmations.
txid := completeChan.FundingOutpoint.Hash txid := completeChan.FundingOutpoint.Hash
numConfs := uint32(completeChan.NumConfsRequired) numConfs := uint32(completeChan.NumConfsRequired)
confNtfn, err := f.cfg.Notifier.RegisterConfirmationsNtfn(&txid, numConfs) confNtfn, err := f.cfg.Notifier.RegisterConfirmationsNtfn(&txid,
numConfs, bestHeight)
if err != nil { if err != nil {
fndgLog.Errorf("Unable to register for confirmation of "+ fndgLog.Errorf("Unable to register for confirmation of "+
"ChannelPoint(%v)", completeChan.FundingOutpoint) "ChannelPoint(%v)", completeChan.FundingOutpoint)