Browse Source

lnrouter: simplify max fee sanity checks

hard-fail-on-bad-server-string
SomberNight 5 years ago
parent
commit
c81335fb44
No known key found for this signature in database GPG Key ID: B33B5F232C6271E9
  1. 36
      electrum/lnrouter.py

36
electrum/lnrouter.py

@ -74,16 +74,11 @@ class RouteEdge(NamedTuple):
def is_sane_to_use(self, amount_msat: int) -> bool: def is_sane_to_use(self, amount_msat: int) -> bool:
# TODO revise ad-hoc heuristics # TODO revise ad-hoc heuristics
# cltv cannot be more than 2 weeks # cltv cannot be more than 2 weeks
if self.cltv_expiry_delta > 14 * 144: return False if self.cltv_expiry_delta > 14 * 144:
return False
total_fee = self.fee_for_edge(amount_msat) total_fee = self.fee_for_edge(amount_msat)
# fees below 50 sat are fine if not is_fee_sane(total_fee, payment_amount_msat=amount_msat):
if total_fee > 50_000: return False
# fee cannot be higher than amt
if total_fee > amount_msat: return False
# fee cannot be higher than 5000 sat
if total_fee > 5_000_000: return False
# unless amt is tiny, fee cannot be more than 10%
if amount_msat > 1_000_000 and total_fee > amount_msat/10: return False
return True return True
@ -105,18 +100,23 @@ def is_route_sane_to_use(route: LNPaymentRoute, invoice_amount_msat: int, min_fi
total_fee = amt - invoice_amount_msat total_fee = amt - invoice_amount_msat
# TODO revise ad-hoc heuristics # TODO revise ad-hoc heuristics
# cltv cannot be more than 2 months # cltv cannot be more than 2 months
if cltv > 60 * 144: return False if cltv > 60 * 144:
# fees below 50 sat are fine return False
if total_fee > 50_000: if not is_fee_sane(total_fee, payment_amount_msat=invoice_amount_msat):
# fee cannot be higher than amt return False
if total_fee > invoice_amount_msat: return False
# fee cannot be higher than 5000 sat
if total_fee > 5_000_000: return False
# unless amt is tiny, fee cannot be more than 10%
if invoice_amount_msat > 1_000_000 and total_fee > invoice_amount_msat/10: return False
return True return True
def is_fee_sane(fee_msat: int, *, payment_amount_msat: int) -> bool:
# fees <= 2 sat are fine
if fee_msat <= 2_000:
return True
# fees <= 1 % of payment are fine
if 100 * fee_msat <= payment_amount_msat:
return True
return False
class LNPathFinder(Logger): class LNPathFinder(Logger):
def __init__(self, channel_db: ChannelDB): def __init__(self, channel_db: ChannelDB):

Loading…
Cancel
Save