Browse Source

handle failing htlc after restart

dependabot/pip/contrib/deterministic-build/ecdsa-0.13.3
SomberNight 6 years ago
committed by ThomasV
parent
commit
864efa029b
  1. 34
      electrum/lnbase.py

34
electrum/lnbase.py

@ -1014,22 +1014,28 @@ class Peer(PrintError):
chan = self.channels[channel_id] chan = self.channels[channel_id]
htlc_id = int.from_bytes(payload["id"], "big") htlc_id = int.from_bytes(payload["id"], "big")
key = (channel_id, htlc_id) key = (channel_id, htlc_id)
route = self.attempted_route[key]
failure_msg, sender_idx = decode_onion_error(payload["reason"], [x.node_id for x in route], chan.onion_keys[htlc_id])
code = failure_msg.code
code_name = ONION_FAILURE_CODE_MAP.get(code, 'unknown_error!!')
data = failure_msg.data
self.print_error("UPDATE_FAIL_HTLC", code_name, code, data)
try: try:
short_chan_id = route[sender_idx + 1].short_channel_id route = self.attempted_route[key]
except IndexError: except KeyError:
self.print_error("payment destination reported error") # the remote might try to fail an htlc after we restarted...
# attempted_route is not persisted, so we will get here then
self.print_error("UPDATE_FAIL_HTLC. cannot decode! attempted route is MISSING. {}".format(key))
else: else:
# TODO this should depend on the error failure_msg, sender_idx = decode_onion_error(payload["reason"], [x.node_id for x in route], chan.onion_keys[htlc_id])
# also, we need finer blacklisting (directed edges; nodes) code = failure_msg.code
self.network.path_finder.blacklist.add(short_chan_id) code_name = ONION_FAILURE_CODE_MAP.get(code, 'unknown_error??')
data = failure_msg.data
self.print_error("HTLC failure with code {} ({})".format(code, code_name)) self.print_error("UPDATE_FAIL_HTLC", code_name, code, data)
try:
short_chan_id = route[sender_idx + 1].short_channel_id
except IndexError:
self.print_error("payment destination reported error")
else:
# TODO this should depend on the error
# also, we need finer blacklisting (directed edges; nodes)
self.network.path_finder.blacklist.add(short_chan_id)
self.print_error("HTLC failure with code {} ({})".format(code, code_name))
# process update_fail_htlc on channel
chan = self.channels[channel_id] chan = self.channels[channel_id]
chan.receive_fail_htlc(htlc_id) chan.receive_fail_htlc(htlc_id)
await self.receive_commitment(chan) await self.receive_commitment(chan)

Loading…
Cancel
Save