Browse Source

get rid of callbacks in lnwatcher, use network events instead

dependabot/pip/contrib/deterministic-build/ecdsa-0.13.3
ThomasV 6 years ago
parent
commit
4441233596
  1. 14
      electrum/lnwatcher.py
  2. 18
      electrum/lnworker.py

14
electrum/lnwatcher.py

@ -27,10 +27,7 @@ class LNWatcher(PrintError):
self.addr_sync.start_network(network) self.addr_sync.start_network(network)
self.lock = threading.RLock() self.lock = threading.RLock()
self.watched_addresses = set() self.watched_addresses = set()
self.channel_info = storage.get('channel_info', {}) # access with 'lock' self.channel_info = storage.get('channel_info', {}) # access with 'lock'
self.funding_txo_spent_callback = {} # funding_outpoint -> callback
# TODO structure will need to change when we handle HTLCs...... # TODO structure will need to change when we handle HTLCs......
# [funding_outpoint_str][ctx_txid] -> set of EncumberedTransaction # [funding_outpoint_str][ctx_txid] -> set of EncumberedTransaction
# access with 'lock' # access with 'lock'
@ -58,12 +55,11 @@ class LNWatcher(PrintError):
storage.put('sweepstore', sweepstore) storage.put('sweepstore', sweepstore)
storage.write() storage.write()
def watch_channel(self, address, outpoint, callback_funding_txo_spent): def watch_channel(self, address, outpoint):
self.watch_address(address) self.watch_address(address)
with self.lock: with self.lock:
if address not in self.channel_info: if address not in self.channel_info:
self.channel_info[address] = outpoint self.channel_info[address] = outpoint
self.funding_txo_spent_callback[outpoint] = callback_funding_txo_spent
self.write_to_disk() self.write_to_disk()
@aiosafe @aiosafe
@ -90,11 +86,9 @@ class LNWatcher(PrintError):
async def check_onchain_situation(self, funding_outpoint): async def check_onchain_situation(self, funding_outpoint):
txid, index = funding_outpoint.split(':') txid, index = funding_outpoint.split(':')
ctx_candidate_txid = self.addr_sync.spent_outpoints[txid].get(int(index)) ctx_candidate_txid = self.addr_sync.spent_outpoints[txid].get(int(index))
# call funding_txo_spent_callback if there is one is_spent = ctx_candidate_txid is not None
is_funding_txo_spent = ctx_candidate_txid is not None self.network.trigger_callback('channel_txo', funding_outpoint, is_spent)
cb = self.funding_txo_spent_callback.get(funding_outpoint) if not is_spent:
if cb: cb(is_funding_txo_spent)
if not is_funding_txo_spent:
return return
ctx_candidate = self.addr_sync.transactions.get(ctx_candidate_txid) ctx_candidate = self.addr_sync.transactions.get(ctx_candidate_txid)
if ctx_candidate is None: if ctx_candidate is None:

18
electrum/lnworker.py

@ -56,11 +56,12 @@ class LNWorker(PrintError):
c.sweep_address = self.sweep_address c.sweep_address = self.sweep_address
self.invoices = wallet.storage.get('lightning_invoices', {}) self.invoices = wallet.storage.get('lightning_invoices', {})
for chan_id, chan in self.channels.items(): for chan_id, chan in self.channels.items():
self.network.lnwatcher.watch_channel(chan.get_funding_address(), chan.funding_outpoint.to_str(), partial(self.on_channel_utxos, chan)) self.network.lnwatcher.watch_channel(chan.get_funding_address(), chan.funding_outpoint.to_str())
self._last_tried_peer = {} # LNPeerAddr -> unix timestamp self._last_tried_peer = {} # LNPeerAddr -> unix timestamp
self._add_peers_from_config() self._add_peers_from_config()
# wait until we see confirmations # wait until we see confirmations
self.network.register_callback(self.on_network_update, ['network_updated', 'verified', 'fee']) # thread safe self.network.register_callback(self.on_network_update, ['network_updated', 'verified', 'fee']) # thread safe
self.network.register_callback(self.on_channel_txo, ['channel_txo'])
asyncio.run_coroutine_threadsafe(self.network.main_taskgroup.spawn(self.main_loop()), self.network.asyncio_loop) asyncio.run_coroutine_threadsafe(self.network.main_taskgroup.spawn(self.main_loop()), self.network.asyncio_loop)
def _read_ln_keystore(self) -> BIP32_KeyStore: def _read_ln_keystore(self) -> BIP32_KeyStore:
@ -145,9 +146,16 @@ class LNWorker(PrintError):
return True, conf return True, conf
return False, conf return False, conf
def on_channel_utxos(self, chan, is_funding_txo_spent: bool): def on_channel_txo(self, event, txo, is_spent: bool):
chan.set_funding_txo_spentness(is_funding_txo_spent) with self.lock:
if is_funding_txo_spent: channels = list(self.channels.values())
for chan in channels:
if chan.funding_outpoint.to_str() == txo:
break
else:
return
chan.set_funding_txo_spentness(is_spent)
if is_spent:
chan.set_state("CLOSED") chan.set_state("CLOSED")
self.channel_db.remove_channel(chan.short_channel_id) self.channel_db.remove_channel(chan.short_channel_id)
self.network.trigger_callback('channel', chan) self.network.trigger_callback('channel', chan)
@ -188,7 +196,7 @@ class LNWorker(PrintError):
push_msat=push_sat * 1000, push_msat=push_sat * 1000,
temp_channel_id=os.urandom(32)) temp_channel_id=os.urandom(32))
self.save_channel(chan) self.save_channel(chan)
self.network.lnwatcher.watch_channel(chan.get_funding_address(), chan.funding_outpoint.to_str(), partial(self.on_channel_utxos, chan)) self.network.lnwatcher.watch_channel(chan.get_funding_address(), chan.funding_outpoint.to_str())
self.on_channels_updated() self.on_channels_updated()
def on_channels_updated(self): def on_channels_updated(self):

Loading…
Cancel
Save