lnd: properly initialize entities of new contractcourt package

This commit is contained in:
Olaoluwa Osuntokun 2018-01-16 20:25:34 -08:00
parent bfbec1c5d3
commit 24a16b4f49
No known key found for this signature in database
GPG Key ID: 964EA263DD637C21
4 changed files with 104 additions and 8 deletions

4
log.go

@ -14,6 +14,7 @@ import (
"github.com/lightningnetwork/lnd/autopilot" "github.com/lightningnetwork/lnd/autopilot"
"github.com/lightningnetwork/lnd/chainntnfs" "github.com/lightningnetwork/lnd/chainntnfs"
"github.com/lightningnetwork/lnd/channeldb" "github.com/lightningnetwork/lnd/channeldb"
"github.com/lightningnetwork/lnd/contractcourt"
"github.com/lightningnetwork/lnd/discovery" "github.com/lightningnetwork/lnd/discovery"
"github.com/lightningnetwork/lnd/htlcswitch" "github.com/lightningnetwork/lnd/htlcswitch"
"github.com/lightningnetwork/lnd/lnwallet" "github.com/lightningnetwork/lnd/lnwallet"
@ -70,6 +71,7 @@ var (
crtrLog = backendLog.Logger("CRTR") crtrLog = backendLog.Logger("CRTR")
btcnLog = backendLog.Logger("BTCN") btcnLog = backendLog.Logger("BTCN")
atplLog = backendLog.Logger("ATPL") atplLog = backendLog.Logger("ATPL")
cnctLog = backendLog.Logger("CNCT")
) )
// Initialize package-global logger variables. // Initialize package-global logger variables.
@ -83,6 +85,7 @@ func init() {
routing.UseLogger(crtrLog) routing.UseLogger(crtrLog)
neutrino.UseLogger(btcnLog) neutrino.UseLogger(btcnLog)
autopilot.UseLogger(atplLog) autopilot.UseLogger(atplLog)
contractcourt.UseLogger(cnctLog)
} }
// subsystemLoggers maps each subsystem identifier to its associated logger. // subsystemLoggers maps each subsystem identifier to its associated logger.
@ -103,6 +106,7 @@ var subsystemLoggers = map[string]btclog.Logger{
"CRTR": crtrLog, "CRTR": crtrLog,
"BTCN": btcnLog, "BTCN": btcnLog,
"ATPL": atplLog, "ATPL": atplLog,
"CNCT": cnctLog,
} }
// initLogRotator initializes the logging rotator to write logs to logFile and // initLogRotator initializes the logging rotator to write logs to logFile and

23
peer.go

@ -10,6 +10,7 @@ import (
"github.com/davecgh/go-spew/spew" "github.com/davecgh/go-spew/spew"
"github.com/lightningnetwork/lnd/brontide" "github.com/lightningnetwork/lnd/brontide"
"github.com/lightningnetwork/lnd/contractcourt"
"bytes" "bytes"
@ -294,8 +295,10 @@ func (p *peer) Start() error {
// channels returned by the database. // channels returned by the database.
func (p *peer) loadActiveChannels(chans []*channeldb.OpenChannel) error { func (p *peer) loadActiveChannels(chans []*channeldb.OpenChannel) error {
for _, dbChan := range chans { for _, dbChan := range chans {
lnChan, err := lnwallet.NewLightningChannel(p.server.cc.signer, lnChan, err := lnwallet.NewLightningChannel(
p.server.cc.chainNotifier, p.server.cc.feeEstimator, dbChan) p.server.cc.signer, p.server.cc.chainNotifier,
p.server.witnessBeacon, dbChan,
)
if err != nil { if err != nil {
return err return err
} }
@ -390,6 +393,12 @@ func (p *peer) loadActiveChannels(chans []*channeldb.OpenChannel) error {
FwrdingPolicy: *forwardingPolicy, FwrdingPolicy: *forwardingPolicy,
FeeEstimator: p.server.cc.feeEstimator, FeeEstimator: p.server.cc.feeEstimator,
BlockEpochs: blockEpoch, BlockEpochs: blockEpoch,
PreimageCache: p.server.witnessBeacon,
UpdateContractSignals: func(signals *contractcourt.ContractSignals) error {
return p.server.chainArb.UpdateContractSignals(
*chanPoint, signals,
)
},
SyncStates: true, SyncStates: true,
} }
link := htlcswitch.NewChannelLink(linkCfg, lnChan, link := htlcswitch.NewChannelLink(linkCfg, lnChan,
@ -1280,6 +1289,12 @@ out:
FwrdingPolicy: p.server.cc.routingPolicy, FwrdingPolicy: p.server.cc.routingPolicy,
FeeEstimator: p.server.cc.feeEstimator, FeeEstimator: p.server.cc.feeEstimator,
BlockEpochs: blockEpoch, BlockEpochs: blockEpoch,
PreimageCache: p.server.witnessBeacon,
UpdateContractSignals: func(signals *contractcourt.ContractSignals) error {
return p.server.chainArb.UpdateContractSignals(
*chanPoint, signals,
)
},
SyncStates: false, SyncStates: false,
} }
link := htlcswitch.NewChannelLink(linkConfig, newChan, link := htlcswitch.NewChannelLink(linkConfig, newChan,
@ -1550,8 +1565,8 @@ func (p *peer) finalizeChanClosure(chanCloser *channelCloser) {
chanCloser.cfg.channel.CancelObserver() chanCloser.cfg.channel.CancelObserver()
// Next, we'll launch a goroutine which will request to be notified by // Next, we'll launch a goroutine which will request to be notified by
// the ChainNotifier once the closure // the ChainNotifier once the closure transaction obtains a single
// transaction obtains a single confirmation. // confirmation.
notifier := p.server.cc.chainNotifier notifier := p.server.cc.chainNotifier
// If any error happens during waitForChanToClose, forward it to // If any error happens during waitForChanToClose, forward it to

@ -1,3 +1,5 @@
// +build !rpctest
package main package main
import ( import (
@ -7,6 +9,7 @@ import (
"github.com/btcsuite/btclog" "github.com/btcsuite/btclog"
"github.com/lightningnetwork/lnd/chainntnfs" "github.com/lightningnetwork/lnd/chainntnfs"
"github.com/lightningnetwork/lnd/channeldb" "github.com/lightningnetwork/lnd/channeldb"
"github.com/lightningnetwork/lnd/contractcourt"
"github.com/lightningnetwork/lnd/htlcswitch" "github.com/lightningnetwork/lnd/htlcswitch"
"github.com/lightningnetwork/lnd/lnrpc" "github.com/lightningnetwork/lnd/lnrpc"
"github.com/lightningnetwork/lnd/lnwallet" "github.com/lightningnetwork/lnd/lnwallet"
@ -23,6 +26,7 @@ func init() {
lnwallet.UseLogger(btclog.Disabled) lnwallet.UseLogger(btclog.Disabled)
htlcswitch.UseLogger(btclog.Disabled) htlcswitch.UseLogger(btclog.Disabled)
channeldb.UseLogger(btclog.Disabled) channeldb.UseLogger(btclog.Disabled)
contractcourt.UseLogger(btclog.Disabled)
} }
// TestPeerChannelClosureAcceptFeeResponder tests the shutdown responder's // TestPeerChannelClosureAcceptFeeResponder tests the shutdown responder's

@ -17,8 +17,10 @@ import (
"github.com/lightningnetwork/lnd/autopilot" "github.com/lightningnetwork/lnd/autopilot"
"github.com/lightningnetwork/lnd/brontide" "github.com/lightningnetwork/lnd/brontide"
"github.com/lightningnetwork/lnd/channeldb" "github.com/lightningnetwork/lnd/channeldb"
"github.com/lightningnetwork/lnd/contractcourt"
"github.com/lightningnetwork/lnd/discovery" "github.com/lightningnetwork/lnd/discovery"
"github.com/lightningnetwork/lnd/lnrpc" "github.com/lightningnetwork/lnd/lnrpc"
"github.com/lightningnetwork/lnd/lnwallet"
"github.com/lightningnetwork/lnd/lnwire" "github.com/lightningnetwork/lnd/lnwire"
"github.com/lightningnetwork/lnd/routing" "github.com/lightningnetwork/lnd/routing"
"github.com/roasbeef/btcd/blockchain" "github.com/roasbeef/btcd/blockchain"
@ -87,7 +89,11 @@ type server struct {
chanDB *channeldb.DB chanDB *channeldb.DB
htlcSwitch *htlcswitch.Switch htlcSwitch *htlcswitch.Switch
invoices *invoiceRegistry invoices *invoiceRegistry
witnessBeacon contractcourt.WitnessBeacon
breachArbiter *breachArbiter breachArbiter *breachArbiter
chanRouter *routing.ChannelRouter chanRouter *routing.ChannelRouter
@ -96,6 +102,8 @@ type server struct {
utxoNursery *utxoNursery utxoNursery *utxoNursery
chainArb *contractcourt.ChainArbitrator
sphinx *htlcswitch.OnionProcessor sphinx *htlcswitch.OnionProcessor
connMgr *connmgr.ConnManager connMgr *connmgr.ConnManager
@ -162,6 +170,8 @@ func newServer(listenAddrs []string, chanDB *channeldb.DB, cc *chainControl,
quit: make(chan struct{}), quit: make(chan struct{}),
} }
s.witnessBeacon = NewPreimageBeacon(s.invoices, chanDB.NewWitnessCache())
// If the debug HTLC flag is on, then we invoice a "master debug" // If the debug HTLC flag is on, then we invoice a "master debug"
// invoice which all outgoing payments will be sent and all incoming // invoice which all outgoing payments will be sent and all incoming
// HTLCs with the debug R-Hash immediately settled. // HTLCs with the debug R-Hash immediately settled.
@ -343,6 +353,55 @@ func newServer(listenAddrs []string, chanDB *channeldb.DB, cc *chainControl,
s.htlcSwitch.CloseLink(chanPoint, closureType, 0) s.htlcSwitch.CloseLink(chanPoint, closureType, 0)
} }
s.chainArb = contractcourt.NewChainArbitrator(contractcourt.ChainArbitratorConfig{
ChainHash: *activeNetParams.GenesisHash,
// TODO(roasbeef): properly configure
// * needs to be << or specified final hop time delta
BroadcastDelta: defaultBroadcastDelta,
NewSweepAddr: func() ([]byte, error) {
return newSweepPkScript(cc.wallet)
},
PublishTx: cc.wallet.PublishTransaction,
DeliverResolutionMsg: func(msgs ...contractcourt.ResolutionMsg) error {
for _, msg := range msgs {
err := s.htlcSwitch.ProcessContractResolution(msg)
if err != nil {
return err
}
}
return nil
},
IncubateOutputs: func(chanPoint wire.OutPoint,
commitRes *lnwallet.CommitOutputResolution,
outHtlcRes *lnwallet.OutgoingHtlcResolution,
inHtlcRes *lnwallet.IncomingHtlcResolution) error {
var (
inRes []lnwallet.IncomingHtlcResolution
outRes []lnwallet.OutgoingHtlcResolution
)
if inHtlcRes != nil {
inRes = append(inRes, *inHtlcRes)
}
if outHtlcRes != nil {
outRes = append(outRes, *outHtlcRes)
}
return s.utxoNursery.IncubateOutputs(
chanPoint, commitRes, outRes, inRes,
)
},
PreimageDB: s.witnessBeacon,
Notifier: cc.chainNotifier,
Signer: cc.wallet.Cfg.Signer,
FeeEstimator: cc.feeEstimator,
ChainIO: cc.chainIO,
MarkLinkInactive: func(chanPoint wire.OutPoint) error {
chanID := lnwire.NewChanIDFromOutPoint(&chanPoint)
return s.htlcSwitch.RemoveLink(chanID)
},
}, chanDB)
s.breachArbiter = newBreachArbiter(&BreachConfig{ s.breachArbiter = newBreachArbiter(&BreachConfig{
CloseLink: closeLink, CloseLink: closeLink,
DB: chanDB, DB: chanDB,
@ -354,6 +413,16 @@ func newServer(listenAddrs []string, chanDB *channeldb.DB, cc *chainControl,
PublishTransaction: cc.wallet.PublishTransaction, PublishTransaction: cc.wallet.PublishTransaction,
Signer: cc.wallet.Cfg.Signer, Signer: cc.wallet.Cfg.Signer,
Store: newRetributionStore(chanDB), Store: newRetributionStore(chanDB),
UpdateCloseSignal: func(op *wire.OutPoint,
ucs chan *lnwallet.UnilateralCloseSummary) error {
signals := &contractcourt.ContractSignals{
HtlcUpdates: make(chan []channeldb.HTLC),
UniCloseSignal: ucs,
}
return s.chainArb.UpdateContractSignals(*op, signals)
},
}) })
// Create the connection manager which will be responsible for // Create the connection manager which will be responsible for
@ -405,6 +474,9 @@ func (s *server) Start() error {
if err := s.utxoNursery.Start(); err != nil { if err := s.utxoNursery.Start(); err != nil {
return err return err
} }
if err := s.chainArb.Start(); err != nil {
return err
}
if err := s.breachArbiter.Start(); err != nil { if err := s.breachArbiter.Start(); err != nil {
return err return err
} }
@ -461,6 +533,7 @@ func (s *server) Stop() error {
s.utxoNursery.Stop() s.utxoNursery.Stop()
s.breachArbiter.Stop() s.breachArbiter.Stop()
s.authGossiper.Stop() s.authGossiper.Stop()
s.chainArb.Stop()
s.cc.wallet.Shutdown() s.cc.wallet.Shutdown()
s.cc.chainView.Stop() s.cc.chainView.Stop()
s.connMgr.Stop() s.connMgr.Stop()