|
@ -120,12 +120,9 @@ class Channel(PrintError): |
|
|
except: |
|
|
except: |
|
|
return super().diagnostic_name() |
|
|
return super().diagnostic_name() |
|
|
|
|
|
|
|
|
def __init__(self, state, *, sweep_address=None, name=None, |
|
|
def __init__(self, state, *, sweep_address=None, name=None, lnworker=None): |
|
|
payment_completed: Optional[Callable[['Channel', Direction, UpdateAddHtlc], None]] = None): |
|
|
self.lnworker = lnworker |
|
|
if not payment_completed: |
|
|
|
|
|
payment_completed = lambda this, x, y: None |
|
|
|
|
|
self.sweep_address = sweep_address |
|
|
self.sweep_address = sweep_address |
|
|
self.payment_completed = payment_completed |
|
|
|
|
|
assert 'local_state' not in state |
|
|
assert 'local_state' not in state |
|
|
self.config = {} |
|
|
self.config = {} |
|
|
self.config[LOCAL] = state["local_config"] |
|
|
self.config[LOCAL] = state["local_config"] |
|
@ -437,10 +434,11 @@ class Channel(PrintError): |
|
|
|
|
|
|
|
|
received = self.hm.received_in_ctn(self.config[LOCAL].ctn) |
|
|
received = self.hm.received_in_ctn(self.config[LOCAL].ctn) |
|
|
sent = self.hm.sent_in_ctn(self.config[LOCAL].ctn) |
|
|
sent = self.hm.sent_in_ctn(self.config[LOCAL].ctn) |
|
|
|
|
|
if self.lnworker: |
|
|
for htlc in received: |
|
|
for htlc in received: |
|
|
self.payment_completed(self, RECEIVED, htlc) |
|
|
self.lnworker.payment_completed(self, RECEIVED, htlc) |
|
|
for htlc in sent: |
|
|
for htlc in sent: |
|
|
self.payment_completed(self, SENT, htlc) |
|
|
self.lnworker.payment_completed(self, SENT, htlc) |
|
|
received_this_batch = htlcsum(received) |
|
|
received_this_batch = htlcsum(received) |
|
|
sent_this_batch = htlcsum(sent) |
|
|
sent_this_batch = htlcsum(sent) |
|
|
|
|
|
|
|
@ -616,11 +614,8 @@ class Channel(PrintError): |
|
|
assert htlc_id not in log['settles'] |
|
|
assert htlc_id not in log['settles'] |
|
|
self.hm.send_settle(htlc_id) |
|
|
self.hm.send_settle(htlc_id) |
|
|
# save timestamp in LNWorker.preimages |
|
|
# save timestamp in LNWorker.preimages |
|
|
try: |
|
|
if self.lnworker: |
|
|
self.save_preimage(htlc.payment_hash, preimage, timestamp=int(time.time())) |
|
|
self.lnworker.save_preimage(htlc.payment_hash, preimage, timestamp=int(time.time())) |
|
|
except: |
|
|
|
|
|
import traceback |
|
|
|
|
|
traceback.print_exc() |
|
|
|
|
|
|
|
|
|
|
|
def receive_htlc_settle(self, preimage, htlc_id): |
|
|
def receive_htlc_settle(self, preimage, htlc_id): |
|
|
self.print_error("receive_htlc_settle") |
|
|
self.print_error("receive_htlc_settle") |
|
@ -629,12 +624,8 @@ class Channel(PrintError): |
|
|
assert htlc.payment_hash == sha256(preimage) |
|
|
assert htlc.payment_hash == sha256(preimage) |
|
|
assert htlc_id not in log['settles'] |
|
|
assert htlc_id not in log['settles'] |
|
|
self.hm.recv_settle(htlc_id) |
|
|
self.hm.recv_settle(htlc_id) |
|
|
try: |
|
|
if self.lnworker: |
|
|
self.save_preimage(htlc.payment_hash, preimage, timestamp=int(time.time())) |
|
|
self.lnworker.save_preimage(htlc.payment_hash, preimage, timestamp=int(time.time())) |
|
|
except AttributeError as e: |
|
|
|
|
|
# save_preimage is not defined in the unit tests... this is ugly as hell. FIXME |
|
|
|
|
|
import traceback |
|
|
|
|
|
traceback.print_exc() |
|
|
|
|
|
|
|
|
|
|
|
def fail_htlc(self, htlc_id): |
|
|
def fail_htlc(self, htlc_id): |
|
|
self.print_error("fail_htlc") |
|
|
self.print_error("fail_htlc") |
|
|