bLIP: 25
Title: Allow forwarding HTLCs with less value than the onion claims to pay
Status: Draft
Author: Valentine Wallace <[email protected]>
Created: 2023-05-22
License: CC0
Penultimate hops in lightning payment paths may want to take an extra fee from the payee's final
received value. To do so, they can simply forward less than the amount encoded in the onion by the
sender, and specify the exact fee they took in a new update_add_htlc
TLV for the receiver to
verify.
This bLIP is licensed under the CC0 license.
We define a TLV field for update_add_htlc
that allows a relaying node to
relay a smaller amount than the amount encoded in the onion:
tlv_stream
:update_add_htlc_tlvs
- types:
- type: 65537 (
extra_fee
) - data:
- [
u64
:amount_msat
]
- [
- type: 65537 (
The writer:
- MUST set
extra_fee
to the amount of extra fee they took from the receiver's final value
The receiver:
- MUST fail the HTLC if they did not expect an extra fee to be taken or if the extra fee taken is too high
- MUST either accept or reject the HTLC as if it had received
htlc_value + extra_fee
For context, it is expected that many lightning users will be connected to the lightning network via Lightning Service Providers (LSPs), who are responsible for managing channel liquidity on end users' behalf.
Often, users are onboarded to these services via a just-in-time inbound channel when they first receive a payment. However, this channel open costs money, and so liquidity providers may want to take an extra fee so that users can help bear the cost of this initial on-chain fee.
While it would be possible to avoid the extra TLV record if receivers could be trusted to calculate that the fee taken by the penultimate hop is as-expected, in practice this may be tricky to get right. If there were a bug in this logic, a sender could exploit it by forwarding less than the invoice's expected value, and receive proof-of-payment that they paid the full value.
See https://github.com/BitcoinAndLightningLayerSpecs/lsp/tree/main/LSPS2#3--invoice-generation for invoice requirements if this feature is being used in the JIT channel context.