fix dict value assignment bug in import_channel_backup. In request_force_close, use Taskgroup with wait=any
This commit is contained in:
@@ -2003,12 +2003,15 @@ class LNWallet(LNWorker):
|
|||||||
xpub = self.wallet.get_fingerprint()
|
xpub = self.wallet.get_fingerprint()
|
||||||
decrypted = pw_decode_with_version_and_mac(encrypted, xpub)
|
decrypted = pw_decode_with_version_and_mac(encrypted, xpub)
|
||||||
cb_storage = ChannelBackupStorage.from_bytes(decrypted)
|
cb_storage = ChannelBackupStorage.from_bytes(decrypted)
|
||||||
channel_id = cb_storage.channel_id().hex()
|
channel_id = cb_storage.channel_id()
|
||||||
if channel_id in self.db.get_dict("channels"):
|
if channel_id.hex() in self.db.get_dict("channels"):
|
||||||
raise Exception('Channel already in wallet')
|
raise Exception('Channel already in wallet')
|
||||||
|
self.logger.info(f'importing channel backup: {channel_id.hex()}')
|
||||||
|
cb = ChannelBackup(cb_storage, sweep_address=self.sweep_address, lnworker=self)
|
||||||
d = self.db.get_dict("channel_backups")
|
d = self.db.get_dict("channel_backups")
|
||||||
d[channel_id] = cb_storage
|
d[channel_id.hex()] = cb_storage
|
||||||
self.channel_backups[bfh(channel_id)] = cb = ChannelBackup(cb_storage, sweep_address=self.sweep_address, lnworker=self)
|
with self.lock:
|
||||||
|
self._channel_backups[channel_id] = cb
|
||||||
self.wallet.save_db()
|
self.wallet.save_db()
|
||||||
util.trigger_callback('channels_updated', self.wallet)
|
util.trigger_callback('channels_updated', self.wallet)
|
||||||
self.lnwatcher.add_channel(cb.funding_outpoint.to_str(), cb.get_funding_address())
|
self.lnwatcher.add_channel(cb.funding_outpoint.to_str(), cb.get_funding_address())
|
||||||
@@ -2025,13 +2028,16 @@ class LNWallet(LNWorker):
|
|||||||
|
|
||||||
@log_exceptions
|
@log_exceptions
|
||||||
async def request_force_close_from_backup(self, channel_id: bytes):
|
async def request_force_close_from_backup(self, channel_id: bytes):
|
||||||
cb = self.channel_backups[channel_id].cb
|
cb = self.channel_backups.get(channel_id)
|
||||||
|
if not cb:
|
||||||
|
raise Exception(f'channel backup not found {self.channel_backups}')
|
||||||
|
cb = cb.cb # storage
|
||||||
|
self.logger.info(f'requesting channel force close: {channel_id.hex()}')
|
||||||
# TODO also try network addresses from gossip db (as it might have changed)
|
# TODO also try network addresses from gossip db (as it might have changed)
|
||||||
peer_addr = LNPeerAddr(cb.host, cb.port, cb.node_id)
|
peer_addr = LNPeerAddr(cb.host, cb.port, cb.node_id)
|
||||||
transport = LNTransport(cb.privkey, peer_addr,
|
transport = LNTransport(cb.privkey, peer_addr, proxy=self.network.proxy)
|
||||||
proxy=self.network.proxy)
|
|
||||||
peer = Peer(self, cb.node_id, transport, is_channel_backup=True)
|
peer = Peer(self, cb.node_id, transport, is_channel_backup=True)
|
||||||
async with TaskGroup() as group:
|
async with TaskGroup(wait=any) as group:
|
||||||
await group.spawn(peer._message_loop())
|
await group.spawn(peer._message_loop())
|
||||||
await group.spawn(peer.trigger_force_close(channel_id))
|
await group.spawn(peer.trigger_force_close(channel_id))
|
||||||
# TODO force-exit taskgroup, to clean-up
|
return True
|
||||||
|
|||||||
Reference in New Issue
Block a user