Browse Source

force-close channel if unfulfilled htlc is close to cltv expiry

dependabot/pip/contrib/deterministic-build/ecdsa-0.13.3
ThomasV 6 years ago
parent
commit
ec97d623a5
  1. 4
      electrum/lnchannel.py
  2. 13
      electrum/lnworker.py

4
electrum/lnchannel.py

@ -603,6 +603,10 @@ class Channel(PrintError):
sub = LOCAL if direction == SENT else REMOTE sub = LOCAL if direction == SENT else REMOTE
return htlcsum(self.hm.settled_htlcs_by(sub, self.config[sub].ctn)) return htlcsum(self.hm.settled_htlcs_by(sub, self.config[sub].ctn))
def get_unfulfilled_htlcs(self):
log = self.hm.log[REMOTE]
return [v for x,v in log['adds'].items() if x not in log['settles']]
def settle_htlc(self, preimage, htlc_id): def settle_htlc(self, preimage, htlc_id):
""" """
SettleHTLC attempts to settle an existing outstanding received HTLC. SettleHTLC attempts to settle an existing outstanding received HTLC.

13
electrum/lnworker.py

@ -368,6 +368,16 @@ class LNWorker(PrintError):
else: else:
self.wallet.add_future_tx(e_tx, remaining) self.wallet.add_future_tx(e_tx, remaining)
def is_dangerous(self, chan):
for x in chan.get_unfulfilled_htlcs():
dust_limit = chan.config[REMOTE].dust_limit_sat * 1000
delay = x.cltv_expiry - self.network.get_local_height()
if x.amount_msat > 10 * dust_limit and delay < 3:
self.print_error('htlc is dangerous')
return True
else:
self.print_error('htlc is not dangerous', delay)
return False
@log_exceptions @log_exceptions
async def on_network_update(self, event, *args): async def on_network_update(self, event, *args):
@ -381,6 +391,9 @@ class LNWorker(PrintError):
if args[0] != lnwatcher: if args[0] != lnwatcher:
return return
for chan in channels: for chan in channels:
if chan.get_state() in ["OPEN", "DISCONNECTED"] and self.is_dangerous(chan):
await self.force_close_channel(chan.channel_id)
continue
if chan.short_channel_id is None: if chan.short_channel_id is None:
self.save_short_chan_id(chan) self.save_short_chan_id(chan)
if chan.get_state() == "OPENING" and chan.short_channel_id: if chan.get_state() == "OPENING" and chan.short_channel_id:

Loading…
Cancel
Save