Browse Source

lnworker.pay_to_node: (fix) pass correct total_msat to pay_to_route

patch-4
SomberNight 4 years ago
parent
commit
adbfb2dcc8
No known key found for this signature in database GPG Key ID: B33B5F232C6271E9
  1. 23
      electrum/lnworker.py

23
electrum/lnworker.py

@ -977,6 +977,7 @@ class LNWallet(LNWorker):
def create_routes_from_invoice(self, amount_msat: int, decoded_invoice: LnAddr, *, full_path=None): def create_routes_from_invoice(self, amount_msat: int, decoded_invoice: LnAddr, *, full_path=None):
return self.create_routes_for_payment( return self.create_routes_for_payment(
amount_msat=amount_msat, amount_msat=amount_msat,
final_total_msat=amount_msat,
invoice_pubkey=decoded_invoice.pubkey.serialize(), invoice_pubkey=decoded_invoice.pubkey.serialize(),
min_cltv_expiry=decoded_invoice.get_min_final_cltv_expiry(), min_cltv_expiry=decoded_invoice.get_min_final_cltv_expiry(),
r_tags=decoded_invoice.get_routing_info('r'), r_tags=decoded_invoice.get_routing_info('r'),
@ -1080,6 +1081,7 @@ class LNWallet(LNWorker):
routes = await run_in_thread(partial( routes = await run_in_thread(partial(
self.create_routes_for_payment, self.create_routes_for_payment,
amount_msat=amount_to_send, amount_msat=amount_to_send,
final_total_msat=amount_to_pay,
invoice_pubkey=node_pubkey, invoice_pubkey=node_pubkey,
min_cltv_expiry=min_cltv_expiry, min_cltv_expiry=min_cltv_expiry,
r_tags=r_tags, r_tags=r_tags,
@ -1288,7 +1290,8 @@ class LNWallet(LNWorker):
@profiler @profiler
def create_routes_for_payment( def create_routes_for_payment(
self, *, self, *,
amount_msat: int, amount_msat: int, # part of payment amount we want routes for now
final_total_msat: int, # total payment amount final receiver will get
invoice_pubkey, invoice_pubkey,
min_cltv_expiry, min_cltv_expiry,
r_tags, t_tags, r_tags, t_tags,
@ -1296,6 +1299,7 @@ class LNWallet(LNWorker):
payment_hash, payment_hash,
payment_secret, payment_secret,
full_path: LNPaymentPath = None) -> Sequence[Tuple[LNPaymentRoute, int]]: full_path: LNPaymentPath = None) -> Sequence[Tuple[LNPaymentRoute, int]]:
# FIXME trampoline case broken if amount_msat != final_total_msat
"""Creates multiple routes for splitting a payment over the available """Creates multiple routes for splitting a payment over the available
private channels. private channels.
@ -1358,7 +1362,7 @@ class LNWallet(LNWorker):
r_tags=r_tags, t_tags=t_tags, r_tags=r_tags, t_tags=t_tags,
invoice_features=invoice_features, invoice_features=invoice_features,
outgoing_channel=None, full_path=full_path) outgoing_channel=None, full_path=full_path)
routes = [(route, amount_msat, amount_msat, min_cltv_expiry, payment_secret, None)] routes = [(route, amount_msat, final_total_msat, min_cltv_expiry, payment_secret, None)]
except NoPathFound: except NoPathFound:
if not invoice_features.supports(LnFeatures.BASIC_MPP_OPT): if not invoice_features.supports(LnFeatures.BASIC_MPP_OPT):
raise raise
@ -1431,7 +1435,7 @@ class LNWallet(LNWorker):
r_tags=r_tags, t_tags=t_tags, r_tags=r_tags, t_tags=t_tags,
invoice_features=invoice_features, invoice_features=invoice_features,
outgoing_channel=channel, full_path=None) outgoing_channel=channel, full_path=None)
routes.append((route, part_amount_msat, amount_msat, min_cltv_expiry, payment_secret, None)) routes.append((route, part_amount_msat, final_total_msat, min_cltv_expiry, payment_secret, None))
self.logger.info(f"found acceptable split configuration: {list(s[0].values())} rating: {s[1]}") self.logger.info(f"found acceptable split configuration: {list(s[0].values())} rating: {s[1]}")
break break
except NoPathFound: except NoPathFound:
@ -1702,12 +1706,13 @@ class LNWallet(LNWorker):
sender_idx = None sender_idx = None
self.logger.info(f"htlc_failed {failure_message}") self.logger.info(f"htlc_failed {failure_message}")
if payment_secret in self.sent_buckets: # FIXME: maybe only check this bucketing stuff if not using trampoline?
self.sent_buckets[payment_secret] -= amount_msat # if payment_secret in self.sent_buckets:
if self.sent_buckets[payment_secret] > 0: # self.sent_buckets[payment_secret] -= amount_msat
return # if self.sent_buckets[payment_secret] > 0:
else: # return
amount_msat = bucket_msat # else:
# amount_msat = bucket_msat
htlc_log = HtlcLog( htlc_log = HtlcLog(
success=False, success=False,
route=route, route=route,

Loading…
Cancel
Save