Browse Source

lnhtlc: small clean-up / docstrings

dependabot/pip/contrib/deterministic-build/ecdsa-0.13.3
SomberNight 6 years ago
committed by ThomasV
parent
commit
8632f027da
  1. 6
      electrum/gui/qt/channel_details.py
  2. 6
      electrum/lnchannel.py
  3. 44
      electrum/lnhtlc.py
  4. 2
      electrum/tests/test_lnhtlc.py

6
electrum/gui/qt/channel_details.py

@ -114,8 +114,10 @@ class ChannelDetailsDialog(QtWidgets.QDialog):
self.update_sent_received() self.update_sent_received()
def update_sent_received(self): def update_sent_received(self):
self.sent_label.setText(str(htlcsum(self.chan.hm.settled_htlcs_by(LOCAL)))) self.sent_label.setText(str(htlcsum(
self.received_label.setText(str(htlcsum(self.chan.hm.settled_htlcs_by(REMOTE)))) self.chan.total_msat(Direction.SENT))))
self.received_label.setText(str(htlcsum(
self.chan.total_msat(Direction.RECEIVED))))
@QtCore.pyqtSlot(str) @QtCore.pyqtSlot(str)
def show_tx(self, link_text: str): def show_tx(self, link_text: str):

6
electrum/lnchannel.py

@ -516,7 +516,7 @@ class Channel(PrintError):
assert type(subject) is HTLCOwner assert type(subject) is HTLCOwner
initial = self.config[subject].initial_msat initial = self.config[subject].initial_msat
for direction, htlc in self.hm.settled_htlcs(subject, ctn): for direction, htlc in self.hm.all_settled_htlcs_ever(subject, ctn):
if direction == SENT: if direction == SENT:
initial -= htlc.amount_msat initial -= htlc.amount_msat
else: else:
@ -594,9 +594,9 @@ class Channel(PrintError):
return self.config[subject].ctn return self.config[subject].ctn
def total_msat(self, direction): def total_msat(self, direction):
"""Return the cumulative total msat amount received/sent so far."""
assert type(direction) is Direction assert type(direction) is Direction
sub = LOCAL if direction == SENT else REMOTE return htlcsum(self.hm.all_settled_htlcs_ever_by_direction(LOCAL, direction))
return htlcsum(self.hm.settled_htlcs_by(sub, self.config[sub].ctn))
def get_unfulfilled_htlcs(self): def get_unfulfilled_htlcs(self):
log = self.hm.log[REMOTE] log = self.hm.log[REMOTE]

44
electrum/lnhtlc.py

@ -8,6 +8,7 @@ from .util import bh2u
class HTLCManager: class HTLCManager:
def __init__(self, local_ctn=0, remote_ctn=0, log=None): def __init__(self, local_ctn=0, remote_ctn=0, log=None):
# self.ctn[sub] is the ctn for the oldest unrevoked ctx of sub
self.ctn = {LOCAL:local_ctn, REMOTE: remote_ctn} self.ctn = {LOCAL:local_ctn, REMOTE: remote_ctn}
self.expect_sig = {SENT: False, RECEIVED: False} self.expect_sig = {SENT: False, RECEIVED: False}
if log is None: if log is None:
@ -16,7 +17,6 @@ class HTLCManager:
else: else:
assert type(log) is dict assert type(log) is dict
log = {HTLCOwner(int(x)): y for x, y in deepcopy(log).items()} log = {HTLCOwner(int(x)): y for x, y in deepcopy(log).items()}
# self.ctn[sub] is the ctn for the oldest unrevoked ctx of sub
for sub in (LOCAL, REMOTE): for sub in (LOCAL, REMOTE):
log[sub]['adds'] = {int(x): UpdateAddHtlc(*y) for x, y in log[sub]['adds'].items()} log[sub]['adds'] = {int(x): UpdateAddHtlc(*y) for x, y in log[sub]['adds'].items()}
coerceHtlcOwner2IntMap = lambda x: {HTLCOwner(int(y)): z for y, z in x.items()} coerceHtlcOwner2IntMap = lambda x: {HTLCOwner(int(y)): z for y, z in x.items()}
@ -83,7 +83,9 @@ class HTLCManager:
def htlcs_by_direction(self, subject: HTLCOwner, direction: Direction, def htlcs_by_direction(self, subject: HTLCOwner, direction: Direction,
ctn: int = None) -> Sequence[UpdateAddHtlc]: ctn: int = None) -> Sequence[UpdateAddHtlc]:
""" """Return the list of received or sent (depending on direction) HTLCs
in subject's ctx at ctn.
direction is relative to subject! direction is relative to subject!
""" """
assert type(subject) is HTLCOwner assert type(subject) is HTLCOwner
@ -91,12 +93,9 @@ class HTLCManager:
if ctn is None: if ctn is None:
ctn = self.ctn[subject] ctn = self.ctn[subject]
l = [] l = []
if direction == SENT and subject == LOCAL: # subject's ctx
party = LOCAL # party is the proposer of the HTLCs
elif direction == RECEIVED and subject == REMOTE: party = subject if direction == SENT else subject.inverted()
party = LOCAL
else:
party = REMOTE
for htlc_id, ctns in self.log[party]['locked_in'].items(): for htlc_id, ctns in self.log[party]['locked_in'].items():
htlc_height = ctns[subject] htlc_height = ctns[subject]
if htlc_height is None: if htlc_height is None:
@ -113,6 +112,7 @@ class HTLCManager:
return l return l
def htlcs(self, subject: HTLCOwner, ctn: int = None) -> Sequence[Tuple[Direction, UpdateAddHtlc]]: def htlcs(self, subject: HTLCOwner, ctn: int = None) -> Sequence[Tuple[Direction, UpdateAddHtlc]]:
"""Return the list of HTLCs in subject's ctx at ctn."""
assert type(subject) is HTLCOwner assert type(subject) is HTLCOwner
if ctn is None: if ctn is None:
ctn = self.ctn[subject] ctn = self.ctn[subject]
@ -122,11 +122,13 @@ class HTLCManager:
return l return l
def current_htlcs(self, subject: HTLCOwner) -> Sequence[Tuple[Direction, UpdateAddHtlc]]: def current_htlcs(self, subject: HTLCOwner) -> Sequence[Tuple[Direction, UpdateAddHtlc]]:
"""Return the list of HTLCs in subject's oldest unrevoked ctx."""
assert type(subject) is HTLCOwner assert type(subject) is HTLCOwner
ctn = self.ctn[subject] ctn = self.ctn[subject]
return self.htlcs(subject, ctn) return self.htlcs(subject, ctn)
def pending_htlcs(self, subject: HTLCOwner) -> Sequence[Tuple[Direction, UpdateAddHtlc]]: def pending_htlcs(self, subject: HTLCOwner) -> Sequence[Tuple[Direction, UpdateAddHtlc]]:
"""Return the list of HTLCs in subject's next ctx (one after oldest unrevoked)."""
assert type(subject) is HTLCOwner assert type(subject) is HTLCOwner
ctn = self.ctn[subject] + 1 ctn = self.ctn[subject] + 1
return self.htlcs(subject, ctn) return self.htlcs(subject, ctn)
@ -137,23 +139,33 @@ class HTLCManager:
def recv_settle(self, htlc_id: int) -> None: def recv_settle(self, htlc_id: int) -> None:
self.log[LOCAL]['settles'][htlc_id] = {LOCAL: self.ctn[LOCAL] + 1, REMOTE: None} self.log[LOCAL]['settles'][htlc_id] = {LOCAL: self.ctn[LOCAL] + 1, REMOTE: None}
def settled_htlcs_by(self, subject: HTLCOwner, ctn: int = None) -> Sequence[UpdateAddHtlc]: def all_settled_htlcs_ever_by_direction(self, subject: HTLCOwner, direction: Direction,
ctn: int = None) -> Sequence[UpdateAddHtlc]:
"""Return the list of all HTLCs that have been ever settled in subject's
ctx up to ctn, filtered to only "direction".
"""
assert type(subject) is HTLCOwner assert type(subject) is HTLCOwner
if ctn is None: if ctn is None:
ctn = self.ctn[subject] ctn = self.ctn[subject]
# subject's ctx
# party is the proposer of the HTLCs
party = subject if direction == SENT else subject.inverted()
d = [] d = []
for htlc_id, ctns in self.log[subject]['settles'].items(): for htlc_id, ctns in self.log[party]['settles'].items():
if ctns[subject] <= ctn: if ctns[subject] is not None and ctns[subject] <= ctn:
d.append(self.log[subject]['adds'][htlc_id]) d.append(self.log[party]['adds'][htlc_id])
return d return d
def settled_htlcs(self, subject: HTLCOwner, ctn: int = None) -> Sequence[Tuple[Direction, UpdateAddHtlc]]: def all_settled_htlcs_ever(self, subject: HTLCOwner, ctn: int = None) \
-> Sequence[Tuple[Direction, UpdateAddHtlc]]:
"""Return the list of all HTLCs that have been ever settled in subject's
ctx up to ctn.
"""
assert type(subject) is HTLCOwner assert type(subject) is HTLCOwner
if ctn is None: if ctn is None:
ctn = self.ctn[subject] ctn = self.ctn[subject]
sent = [(SENT, x) for x in self.settled_htlcs_by(subject, ctn)] sent = [(SENT, x) for x in self.all_settled_htlcs_ever_by_direction(subject, SENT, ctn)]
other = subject.inverted() received = [(RECEIVED, x) for x in self.all_settled_htlcs_ever_by_direction(subject, RECEIVED, ctn)]
received = [(RECEIVED, x) for x in self.settled_htlcs_by(other, ctn)]
return sent + received return sent + received
def received_in_ctn(self, ctn: int) -> Sequence[UpdateAddHtlc]: def received_in_ctn(self, ctn: int) -> Sequence[UpdateAddHtlc]:

2
electrum/tests/test_lnhtlc.py

@ -84,7 +84,7 @@ class TestHTLCManager(unittest.TestCase):
self.assertEqual(A.current_htlcs(LOCAL), []) self.assertEqual(A.current_htlcs(LOCAL), [])
self.assertEqual(A.current_htlcs(REMOTE), []) self.assertEqual(A.current_htlcs(REMOTE), [])
self.assertEqual(B.current_htlcs(REMOTE), []) self.assertEqual(B.current_htlcs(REMOTE), [])
self.assertEqual(len(A.settled_htlcs(LOCAL)), 1) self.assertEqual(len(A.all_settled_htlcs_ever(LOCAL)), 1)
self.assertEqual(len(A.sent_in_ctn(2)), 1) self.assertEqual(len(A.sent_in_ctn(2)), 1)
self.assertEqual(len(B.received_in_ctn(2)), 1) self.assertEqual(len(B.received_in_ctn(2)), 1)

Loading…
Cancel
Save