Browse Source

lnrater: don't suggest nodes we have a channel backup with

We don't want to connect to nodes we already have a channel with on another device.
patch-4
SomberNight 4 years ago
parent
commit
a509573ea0
No known key found for this signature in database GPG Key ID: B33B5F232C6271E9
  1. 17
      electrum/lnchannel.py
  2. 11
      electrum/lnrater.py

17
electrum/lnchannel.py

@ -59,7 +59,7 @@ from .lnhtlc import HTLCManager
from .lnmsg import encode_msg, decode_msg from .lnmsg import encode_msg, decode_msg
from .address_synchronizer import TX_HEIGHT_LOCAL from .address_synchronizer import TX_HEIGHT_LOCAL
from .lnutil import CHANNEL_OPENING_TIMEOUT from .lnutil import CHANNEL_OPENING_TIMEOUT
from .lnutil import ChannelBackupStorage, ImportedChannelBackupStorage from .lnutil import ChannelBackupStorage, ImportedChannelBackupStorage, OnchainChannelBackupStorage
from .lnutil import format_short_channel_id from .lnutil import format_short_channel_id
if TYPE_CHECKING: if TYPE_CHECKING:
@ -148,7 +148,7 @@ class AbstractChannel(Logger, ABC):
_fallback_sweep_address: str _fallback_sweep_address: str
channel_id: bytes channel_id: bytes
funding_outpoint: Outpoint funding_outpoint: Outpoint
node_id: bytes node_id: bytes # note that it might not be the full 33 bytes; for OCB it is only the prefix
_state: ChannelState _state: ChannelState
def set_short_channel_id(self, short_id: ShortChannelID) -> None: def set_short_channel_id(self, short_id: ShortChannelID) -> None:
@ -391,6 +391,11 @@ class AbstractChannel(Logger, ABC):
def is_static_remotekey_enabled(self) -> bool: def is_static_remotekey_enabled(self) -> bool:
pass pass
@abstractmethod
def get_local_pubkey(self) -> bytes:
"""Returns our node ID."""
pass
class ChannelBackup(AbstractChannel): class ChannelBackup(AbstractChannel):
""" """
@ -513,6 +518,14 @@ class ChannelBackup(AbstractChannel):
# their local config is not static) # their local config is not static)
return False return False
def get_local_pubkey(self) -> bytes:
cb = self.cb
assert isinstance(cb, ChannelBackupStorage)
if isinstance(cb, ImportedChannelBackupStorage):
return ecc.ECPrivkey(cb.privkey).get_public_key_bytes(compressed=True)
if isinstance(cb, OnchainChannelBackupStorage):
return self.lnworker.node_keypair.pubkey
raise NotImplementedError(f"unexpected cb type: {type(cb)}")
class Channel(AbstractChannel): class Channel(AbstractChannel):

11
electrum/lnrater.py

@ -243,6 +243,9 @@ class LNRater(Logger):
node_keys = list(self._node_stats.keys()) node_keys = list(self._node_stats.keys())
node_ratings = list(self._node_ratings.values()) node_ratings = list(self._node_ratings.values())
channel_peers = self.lnworker.channel_peers() channel_peers = self.lnworker.channel_peers()
channel_backup_peers = [
cb.node_id for cb in self.lnworker.channel_backups.values()
if (not cb.is_closed() and cb.get_local_pubkey() == self.lnworker.node_keypair.pubkey)]
node_info: Optional["NodeInfo"] = None node_info: Optional["NodeInfo"] = None
while True: while True:
@ -258,8 +261,12 @@ class LNRater(Logger):
continue continue
# don't want to connect to nodes we are already connected to # don't want to connect to nodes we are already connected to
if pk not in channel_peers: if pk in channel_peers:
break continue
# don't want to connect to nodes we already have a channel with on another device
if any(pk.startswith(cb_peer_nodeid) for cb_peer_nodeid in channel_backup_peers):
continue
break
alias = node_info.alias if node_info else 'unknown node alias' alias = node_info.alias if node_info else 'unknown node alias'
self.logger.info( self.logger.info(

Loading…
Cancel
Save