lnd: make NumRequiredConfs and RequiredRemoteDelay scale with chanAmt
This commit makes the value returned fomr NumRequiredConfs and RequiredRemoteDelay used during the funding process scale linearly with the channel size. This is done to ensure that in cases there are more at stake in a channel, we have more time to react to reorgs, or unilateral closes. If the user explicitly specified values for these two at startup, we return those instead, without doing the scaling.
This commit is contained in:
parent
3edc1a7456
commit
43d7dd3d99
71
lnd.go
71
lnd.go
@ -298,16 +298,71 @@ func lndMain() error {
|
|||||||
return nil, fmt.Errorf("unable to find channel")
|
return nil, fmt.Errorf("unable to find channel")
|
||||||
},
|
},
|
||||||
DefaultRoutingPolicy: activeChainControl.routingPolicy,
|
DefaultRoutingPolicy: activeChainControl.routingPolicy,
|
||||||
NumRequiredConfs: func(chanAmt btcutil.Amount, pushAmt lnwire.MilliSatoshi) uint16 {
|
NumRequiredConfs: func(chanAmt btcutil.Amount,
|
||||||
// TODO(roasbeef): add configurable mapping
|
pushAmt lnwire.MilliSatoshi) uint16 {
|
||||||
// * simple switch initially
|
// For large channels we increase the number
|
||||||
// * assign coefficient, etc
|
// of confirmations we require for the
|
||||||
return uint16(cfg.Bitcoin.DefaultNumChanConfs)
|
// channel to be considered open. As it is
|
||||||
|
// always the responder that gets to choose
|
||||||
|
// value, the pushAmt is value being pushed
|
||||||
|
// to us. This means we have more to lose
|
||||||
|
// in the case this gets re-orged out, and
|
||||||
|
// we will require more confirmations before
|
||||||
|
// we consider it open.
|
||||||
|
// TODO(halseth): Use Litecoin params in case
|
||||||
|
// of LTC channels.
|
||||||
|
|
||||||
|
// In case the user has explicitly specified
|
||||||
|
// a default value for the number of
|
||||||
|
// confirmations, we use it.
|
||||||
|
defaultConf := uint16(cfg.Bitcoin.DefaultNumChanConfs)
|
||||||
|
if defaultConf != 0 {
|
||||||
|
return defaultConf
|
||||||
|
}
|
||||||
|
|
||||||
|
// If not we return a value scaled linearly
|
||||||
|
// between 3 and 6, depending on channel size.
|
||||||
|
// TODO(halseth): Use 1 as minimum?
|
||||||
|
minConf := uint64(3)
|
||||||
|
maxConf := uint64(6)
|
||||||
|
maxChannelSize := uint64(
|
||||||
|
lnwire.NewMSatFromSatoshis(maxFundingAmount))
|
||||||
|
stake := lnwire.NewMSatFromSatoshis(chanAmt) + pushAmt
|
||||||
|
conf := maxConf * uint64(stake) / maxChannelSize
|
||||||
|
if conf < minConf {
|
||||||
|
conf = minConf
|
||||||
|
}
|
||||||
|
if conf > maxConf {
|
||||||
|
conf = maxConf
|
||||||
|
}
|
||||||
|
return uint16(conf)
|
||||||
},
|
},
|
||||||
RequiredRemoteDelay: func(chanAmt btcutil.Amount) uint16 {
|
RequiredRemoteDelay: func(chanAmt btcutil.Amount) uint16 {
|
||||||
// TODO(roasbeef): add additional hooks for
|
// We scale the remote CSV delay (the time the
|
||||||
// configuration
|
// remote have to claim funds in case of a unilateral
|
||||||
return 4
|
// close) linearly from minRemoteDelay blocks
|
||||||
|
// for small channels, to maxRemoteDelay blocks
|
||||||
|
// for channels of size maxFundingAmount.
|
||||||
|
// TODO(halseth): Litecoin parameter for LTC.
|
||||||
|
|
||||||
|
// In case the user has explicitly specified
|
||||||
|
// a default value for the remote delay, we
|
||||||
|
// use it.
|
||||||
|
defaultDelay := uint16(cfg.Bitcoin.DefaultRemoteDelay)
|
||||||
|
if defaultDelay > 0 {
|
||||||
|
return defaultDelay
|
||||||
|
}
|
||||||
|
|
||||||
|
// If not we scale according to channel size.
|
||||||
|
delay := uint16(maxRemoteDelay *
|
||||||
|
chanAmt / maxFundingAmount)
|
||||||
|
if delay < minRemoteDelay {
|
||||||
|
delay = minRemoteDelay
|
||||||
|
}
|
||||||
|
if delay > maxRemoteDelay {
|
||||||
|
delay = maxRemoteDelay
|
||||||
|
}
|
||||||
|
return delay
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Loading…
Reference in New Issue
Block a user