Skip to content

Commit ef02b9e

Browse files
Fix ser for PaymentRelay and PaymentConstraints.
Two fields were serialized as u32/u64 when the spec said *tu32/tu64*. /facepalm.
1 parent 4bab9c8 commit ef02b9e

File tree

2 files changed

+36
-10
lines changed

2 files changed

+36
-10
lines changed

lightning/src/blinded_path/payment.rs

Lines changed: 29 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,7 @@ use crate::ln::features::BlindedHopFeatures;
1313
use crate::ln::msgs::DecodeError;
1414
use crate::offers::invoice::BlindedPayInfo;
1515
use crate::prelude::*;
16-
use crate::util::ser::{Readable, Writeable, Writer};
16+
use crate::util::ser::{HighZeroBytesDroppedBigSize, Readable, Writeable, Writer};
1717

1818
use core::convert::TryFrom;
1919

@@ -275,16 +275,35 @@ pub(super) fn compute_payinfo(
275275
})
276276
}
277277

278-
impl_writeable_msg!(PaymentRelay, {
279-
cltv_expiry_delta,
280-
fee_proportional_millionths,
281-
fee_base_msat
282-
}, {});
278+
impl Writeable for PaymentRelay {
279+
fn write<W: Writer>(&self, w: &mut W) -> Result<(), io::Error> {
280+
self.cltv_expiry_delta.write(w)?;
281+
self.fee_proportional_millionths.write(w)?;
282+
HighZeroBytesDroppedBigSize(self.fee_base_msat).write(w)
283+
}
284+
}
285+
impl Readable for PaymentRelay {
286+
fn read<R: io::Read>(r: &mut R) -> Result<Self, DecodeError> {
287+
let cltv_expiry_delta: u16 = Readable::read(r)?;
288+
let fee_proportional_millionths: u32 = Readable::read(r)?;
289+
let fee_base_msat: HighZeroBytesDroppedBigSize<u32> = Readable::read(r)?;
290+
Ok(Self { cltv_expiry_delta, fee_proportional_millionths, fee_base_msat: fee_base_msat.0 })
291+
}
292+
}
283293

284-
impl_writeable_msg!(PaymentConstraints, {
285-
max_cltv_expiry,
286-
htlc_minimum_msat
287-
}, {});
294+
impl Writeable for PaymentConstraints {
295+
fn write<W: Writer>(&self, w: &mut W) -> Result<(), io::Error> {
296+
self.max_cltv_expiry.write(w)?;
297+
HighZeroBytesDroppedBigSize(self.htlc_minimum_msat).write(w)
298+
}
299+
}
300+
impl Readable for PaymentConstraints {
301+
fn read<R: io::Read>(r: &mut R) -> Result<Self, DecodeError> {
302+
let max_cltv_expiry: u32 = Readable::read(r)?;
303+
let htlc_minimum_msat: HighZeroBytesDroppedBigSize<u64> = Readable::read(r)?;
304+
Ok(Self { max_cltv_expiry, htlc_minimum_msat: htlc_minimum_msat.0 })
305+
}
306+
}
288307

289308
#[cfg(test)]
290309
mod tests {
Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
## Bug fixes
2+
3+
* LDK previously serialized `PaymentRelay::fee_base_msat` as a u32 when it
4+
should have been serialized as a tu32. Similarly, we were serializing
5+
`PaymentConstraints::htlc_minimum_msat` as a u64 when we should have been
6+
serializing it as tu64. This caused lack of interoperability when using other
7+
implementations as forwarding nodes along blinded payment paths.

0 commit comments

Comments
 (0)