From 7a62074f8e528f67bbd6ae3cf1afc4d7f57df512 Mon Sep 17 00:00:00 2001 From: bitromortac Date: Fri, 18 Dec 2020 07:09:48 +0100 Subject: [PATCH] lnchannel: reflect frozen amounts and disconnected channels in the num_sats_can_send/receive methods of the lnwallet. --- electrum/lnchannel.py | 3 +++ electrum/lnworker.py | 22 +++++++++++++++------- 2 files changed, 18 insertions(+), 7 deletions(-) diff --git a/electrum/lnchannel.py b/electrum/lnchannel.py index 824553678..6a97910c8 100644 --- a/electrum/lnchannel.py +++ b/electrum/lnchannel.py @@ -530,6 +530,9 @@ class Channel(AbstractChannel): def is_initiator(self): return self.constraints.is_initiator + def is_active(self): + return self.get_state() == ChannelState.OPEN and self.peer_state == PeerState.GOOD + def funding_txn_minimum_depth(self): return self.constraints.funding_txn_minimum_depth diff --git a/electrum/lnworker.py b/electrum/lnworker.py index 4d363dd06..901b6095a 100644 --- a/electrum/lnworker.py +++ b/electrum/lnworker.py @@ -1376,15 +1376,23 @@ class LNWallet(LNWorker): return Decimal(sum(chan.balance(LOCAL) if not chan.is_closed() else 0 for chan in self.channels.values())) / 1000 - def num_sats_can_send(self) -> Union[Decimal, int]: + def num_sats_can_send(self) -> Decimal: + send_values = [Decimal(0)] with self.lock: - return Decimal(max(chan.available_to_spend(LOCAL) if chan.is_open() else 0 - for chan in self.channels.values()))/1000 if self.channels else 0 - - def num_sats_can_receive(self) -> Union[Decimal, int]: + if self.channels: + for c in self.channels.values(): + if c.is_active() and not c.is_frozen_for_sending(): + send_values.append(Decimal(c.available_to_spend(LOCAL)) / 1000) + return max(send_values) + + def num_sats_can_receive(self) -> Decimal: + receive_values = [Decimal(0)] with self.lock: - return Decimal(max(chan.available_to_spend(REMOTE) if chan.is_open() else 0 - for chan in self.channels.values()))/1000 if self.channels else 0 + if self.channels: + for c in self.channels.values(): + if c.is_active() and not c.is_frozen_for_receiving(): + receive_values.append(Decimal(c.available_to_spend(REMOTE)) / 1000) + return max(receive_values) def can_pay_invoice(self, invoice: LNInvoice) -> bool: return invoice.get_amount_sat() <= self.num_sats_can_send()