|
@ -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, |
|
|