lnd/docs/release-notes/release-notes-0.18.0.md
2024-01-18 18:53:46 +08:00

11 KiB

Release Notes

Bug Fixes

  • Fix a bug where sendcoins command with --sweepall flag would not show the correct amount.

  • Fixed a potential case that when sweeping inputs with locktime, an unexpected lower fee rate is applied.

  • LND will now enforce pong responses from its peers

  • Fixed a possible unintended RBF attempt when sweeping new inputs with retried ones.

  • Fixed a case where lnd might panic due to empty witness data found in a transaction. More details can be found here.

  • Fixed a case where it's possible a failed payment might be stuck in pending.

  • Ensure that a valid SCID is used when marking a zombie edge as live.

  • Remove sweep transactions of the same exclusive group. When using neutrino as a backend unconfirmed transactions have to be removed from the wallet when a conflicting tx is confirmed. For other backends these unconfirmed transactions are already removed. In addition a new walletrpc endpoint RemoveTransaction is introduced which let one easily remove unconfirmed transaction manually.

  • Fixed a case where lnd might dip below its channel reserve when htlcs are added concurrently. A fee buffer (additional balance) is now always kept on the local side ONLY if the channel was opened locally. This is in accordance with the BOTL 02 specification and protects against sharp fee changes because there is always this buffer which can be used to increase the commitment fee and it also protects against the case where htlcs are added asynchronously resulting in stuck channels.

  • Properly handle un-acked updates for exhausted watchtower sessions

New Features

Functional Enhancements

  • A new config value, sweeper.maxfeerate, is added so users can specify the max allowed fee rate when sweeping onchain funds. The default value is 1000 sat/vb. Setting this value below 100 sat/vb is not allowed, as low fee rate can cause transactions not confirming in time, which could result in fund loss. Please note that the actual fee rate to be used is deteremined by the fee estimator used(for instance bitcoind), and this value is a cap on the max allowed value. So it's expected that this cap is rarely hit unless there's mempool congestion.

  • Support for [pathfinding]((https://github.com/lightningnetwork/lnd/pull/7267) and payment to blinded paths has been added via the QueryRoutes (and SendToRouteV2) APIs. This functionality is surfaced in lncli queryroutes where the required flags are tagged with (blinded paths). Updates to mission control to handle pathfinding errors for blinded paths are also included.

  • A new config value, http-header-timeout, is added so users can specify the amount of time the http server will wait for a request to complete before closing the connection. The default value is 5 seconds.

  • routerrpc.usestatusinitiated is introduced to signal that the new payment status Payment_INITIATED should be used for payment-related RPCs. It's recommended to use it to provide granular controls over payments.

  • A helper command (lncli encryptdebugpackage) for collecting and encrypting useful debug information was added. This allows a user to collect the most relevant information about their node with a single command and securely encrypt it to the public key of a developer or support person. That way the person supporting the user with their issue has an eas way to get all the information they usually require without the user needing to publicly give away a lot of privacy-sensitive data.

RPC Additions

lncli Additions

Improvements

Functional Updates

Tlv

Misc

  • Added full validation for blinded path payloads to allow fuzzing before LND fully supports blinded payment relay.

Logging

  • Add the htlc amount to contract court logs in case of timed-out htlcs in order to easily spot dust outputs.

RPC Updates

  • Deprecated StatusUnknown from the payment's rpc response in its status and replaced it with StatusInitiated to explicitly report its current state.

  • Add an option to sign/verify a tagged hash to the signer.SignMessage/signer.VerifyMessage RPCs.

  • sendtoroute will return an error when it's called using the flag --skip_temp_err on a payment that's not a MPP. This is needed as a temp error is defined as a routing error found in one of a MPP's HTLC attempts. If, however, there's only one HTLC attempt, when it's failed, this payment is considered failed, thus there's no such thing as temp error for a non-MPP.

  • Support for MinConf(minimum number of confirmations) has been added to the WalletBalance RPC call.

lncli Updates

Code Health

  • Remove Litecoin code. With this change, the Bitcoin.Active config option is now deprecated since Bitcoin is now the only supported chain. The chains field in the lnrpc.GetInfoResponse message along with the chain field in the lnrpc.Chain message have also been deprecated for the same reason.

  • The payment lifecycle code has been refactored to improve its maintainablity. In particular, the complexity involved in the lifecycle loop has been decoupled into logical steps, with each step having its own responsibility, making it easier to reason about the payment flow.

  • Add a watchtower tower client multiplexer to manage tower clients of different types.

  • Introduce CommitmentType and JusticeKit interface to simplify the code.

Breaking Changes

Performance Improvements

Technical and Architectural Updates

BOLT Spec Updates

  • Add Dynamic Commitment Wire Types. This change begins the development of Dynamic Commitments allowing for the negotiation of new channel parameters and the upgrading of channel types.

  • Start using the timestamps query option in the query_channel_range message. This will allow us to know if our peer has a newer update for a channel that we have marked as a zombie. This addition can be switched off using the new protocol.no-timestamp-query-option config option.

  • Update min_final_cltv_expiry_delta. This only effects external invoices which do not supply the min_final_cltv_expiry parameter. LND has NOT allowed the creation of invoices with a lower min_final_cltv_expiry_delta value than 18 blocks since LND 0.11.0.

Testing

Database

Code Health

Tooling and Documentation

Contributors (Alphabetical Order)

  • Amin Bashiri
  • Andras Banki-Horvath
  • Carla Kirk-Cohen
  • Elle Mouton
  • ErikEk
  • Keagan McClelland
  • Marcos Fernandez Perez
  • Matt Morehouse
  • Slyghtning
  • Turtle
  • Ononiwu Maureen Chiamaka
  • Yong Yu
  • Ziggie