Skip to content

Commit 51ac009

Browse files
AsyncPaymentsMessageHandler trait for OnionMessenger
Add a trait for handling async payments messages to OnionMessenger. This allows users to either provide their own custom handling for async payments messages or rely on a version provided by LDK.
1 parent 3c344ad commit 51ac009

File tree

6 files changed

+116
-21
lines changed

6 files changed

+116
-21
lines changed

fuzz/src/onion_message.rs

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,7 @@ use lightning::ln::msgs::{self, DecodeError, OnionMessageHandler};
1212
use lightning::ln::script::ShutdownScript;
1313
use lightning::offers::invoice::UnsignedBolt12Invoice;
1414
use lightning::offers::invoice_request::UnsignedInvoiceRequest;
15+
use lightning::onion_message::async_payments::{AsyncPaymentsMessage, AsyncPaymentsMessageHandler};
1516
use lightning::onion_message::messenger::{
1617
CustomOnionMessageHandler, Destination, MessageRouter, OnionMessagePath, OnionMessenger,
1718
PendingOnionMessage, Responder, ResponseInstruction,
@@ -39,6 +40,7 @@ pub fn do_test<L: Logger>(data: &[u8], logger: &L) {
3940
let node_id_lookup = EmptyNodeIdLookUp {};
4041
let message_router = TestMessageRouter {};
4142
let offers_msg_handler = TestOffersMessageHandler {};
43+
let async_payments_msg_handler = TestAsyncPaymentsMessageHandler {};
4244
let custom_msg_handler = TestCustomMessageHandler {};
4345
let onion_messenger = OnionMessenger::new(
4446
&keys_manager,
@@ -47,6 +49,7 @@ pub fn do_test<L: Logger>(data: &[u8], logger: &L) {
4749
&node_id_lookup,
4850
&message_router,
4951
&offers_msg_handler,
52+
&async_payments_msg_handler,
5053
&custom_msg_handler,
5154
);
5255

@@ -105,6 +108,16 @@ impl OffersMessageHandler for TestOffersMessageHandler {
105108
}
106109
}
107110

111+
struct TestAsyncPaymentsMessageHandler {}
112+
113+
impl AsyncPaymentsMessageHandler for TestAsyncPaymentsMessageHandler {
114+
fn handle_message(
115+
&self, _message: AsyncPaymentsMessage, _responder: Option<Responder>,
116+
) -> ResponseInstruction<AsyncPaymentsMessage> {
117+
ResponseInstruction::NoResponse
118+
}
119+
}
120+
108121
#[derive(Debug)]
109122
struct TestCustomMessage {}
110123

lightning/src/ln/functional_test_utils.rs

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -421,6 +421,7 @@ type TestOnionMessenger<'chan_man, 'node_cfg, 'chan_mon_cfg> = OnionMessenger<
421421
&'node_cfg test_utils::TestMessageRouter<'chan_mon_cfg>,
422422
&'chan_man TestChannelManager<'node_cfg, 'chan_mon_cfg>,
423423
IgnoringMessageHandler,
424+
IgnoringMessageHandler,
424425
>;
425426

426427
/// For use with [`OnionMessenger`] otherwise `test_restored_packages_retry` will fail. This is
@@ -3228,7 +3229,7 @@ pub fn create_network<'a, 'b: 'a, 'c: 'b>(node_count: usize, cfgs: &'b Vec<NodeC
32283229
let dedicated_entropy = DedicatedEntropy(RandomBytes::new([i as u8; 32]));
32293230
let onion_messenger = OnionMessenger::new(
32303231
dedicated_entropy, cfgs[i].keys_manager, cfgs[i].logger, &chan_mgrs[i],
3231-
&cfgs[i].message_router, &chan_mgrs[i], IgnoringMessageHandler {},
3232+
&cfgs[i].message_router, &chan_mgrs[i], IgnoringMessageHandler {}, IgnoringMessageHandler {},
32323233
);
32333234
let gossip_sync = P2PGossipSync::new(cfgs[i].network_graph.as_ref(), None, cfgs[i].logger);
32343235
let wallet_source = Arc::new(test_utils::TestWalletSource::new(SecretKey::from_slice(&[i as u8 + 1; 32]).unwrap()));

lightning/src/ln/peer_handler.rs

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -28,6 +28,7 @@ use crate::util::ser::{VecWriter, Writeable, Writer};
2828
use crate::ln::peer_channel_encryptor::{PeerChannelEncryptor, NextNoiseStep, MessageBuf, MSG_BUF_ALLOC_SIZE};
2929
use crate::ln::wire;
3030
use crate::ln::wire::{Encode, Type};
31+
use crate::onion_message::async_payments::{AsyncPaymentsMessage, AsyncPaymentsMessageHandler};
3132
use crate::onion_message::messenger::{CustomOnionMessageHandler, PendingOnionMessage, Responder, ResponseInstruction};
3233
use crate::onion_message::offers::{OffersMessage, OffersMessageHandler};
3334
use crate::onion_message::packet::OnionMessageContents;
@@ -148,6 +149,11 @@ impl OffersMessageHandler for IgnoringMessageHandler {
148149
ResponseInstruction::NoResponse
149150
}
150151
}
152+
impl AsyncPaymentsMessageHandler for IgnoringMessageHandler {
153+
fn handle_message(&self, _message: AsyncPaymentsMessage, _responder: Option<Responder>) -> ResponseInstruction<AsyncPaymentsMessage> {
154+
ResponseInstruction::NoResponse
155+
}
156+
}
151157
impl CustomOnionMessageHandler for IgnoringMessageHandler {
152158
type CustomMessage = Infallible;
153159
fn handle_custom_message(&self, _message: Self::CustomMessage, _responder: Option<Responder>) -> ResponseInstruction<Self::CustomMessage> {

lightning/src/onion_message/async_payments.rs

Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11,13 +11,54 @@
1111
1212
use crate::io;
1313
use crate::ln::msgs::DecodeError;
14+
use crate::onion_message::messenger::PendingOnionMessage;
15+
use crate::onion_message::messenger::{Responder, ResponseInstruction};
1416
use crate::onion_message::packet::OnionMessageContents;
1517
use crate::util::ser::{Readable, ReadableArgs, Writeable, Writer};
1618

1719
// TLV record types for the `onionmsg_tlv` TLV stream as defined in BOLT 4.
1820
const HELD_HTLC_AVAILABLE_TLV_TYPE: u64 = 72;
1921
const RELEASE_HELD_HTLC_TLV_TYPE: u64 = 74;
2022

23+
/// A handler for an [`OnionMessage`] containing an async payments message as its payload.
24+
///
25+
/// [`OnionMessage`]: crate::ln::msgs::OnionMessage
26+
pub trait AsyncPaymentsMessageHandler {
27+
/// Handles the given message by either releasing a held HTLC, sending a payment, or replying with
28+
/// an error.
29+
///
30+
/// The returned [`AsyncPaymentsMessage`], if any, is enqueued to be sent by [`OnionMessenger`].
31+
///
32+
/// [`OnionMessenger`]: crate::onion_message::messenger::OnionMessenger
33+
fn handle_message(
34+
&self, message: AsyncPaymentsMessage, responder: Option<Responder>,
35+
) -> ResponseInstruction<AsyncPaymentsMessage>;
36+
37+
/// Releases any [`AsyncPaymentsMessage`]s that need to be sent.
38+
///
39+
/// Typically, this is used for messages initiating an async payment flow rather than in response
40+
/// to another message. The latter should use the return value of [`Self::handle_message`].
41+
#[cfg(not(c_bindings))]
42+
fn release_pending_messages(&self) -> Vec<PendingOnionMessage<AsyncPaymentsMessage>> {
43+
vec![]
44+
}
45+
46+
/// Releases any [`AsyncPaymentsMessage`]s that need to be sent.
47+
///
48+
/// Typically, this is used for messages initiating a payment flow rather than in response to
49+
/// another message. The latter should use the return value of [`Self::handle_message`].
50+
#[cfg(c_bindings)]
51+
fn release_pending_messages(
52+
&self,
53+
) -> Vec<(
54+
AsyncPaymentsMessage,
55+
crate::onion_message::messenger::Destination,
56+
Option<crate::blinded_path::BlindedPath>,
57+
)> {
58+
vec![]
59+
}
60+
}
61+
2162
/// Possible async payment messages sent and received via an [`OnionMessage`].
2263
///
2364
/// [`OnionMessage`]: crate::ln::msgs::OnionMessage

lightning/src/onion_message/functional_tests.rs

Lines changed: 13 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@ use crate::routing::test_utils::{add_channel, add_or_update_node};
1919
use crate::sign::{NodeSigner, Recipient};
2020
use crate::util::ser::{FixedLengthReader, LengthReadable, Writeable, Writer};
2121
use crate::util::test_utils;
22+
use super::async_payments::{AsyncPaymentsMessage, AsyncPaymentsMessageHandler};
2223
use super::messenger::{CustomOnionMessageHandler, DefaultMessageRouter, Destination, OnionMessagePath, OnionMessenger, PendingOnionMessage, Responder, ResponseInstruction, SendError, SendSuccess};
2324
use super::offers::{OffersMessage, OffersMessageHandler};
2425
use super::packet::{OnionMessageContents, Packet};
@@ -50,6 +51,7 @@ struct MessengerNode {
5051
Arc<test_utils::TestKeysInterface>
5152
>>,
5253
Arc<TestOffersMessageHandler>,
54+
Arc<TestAsyncPaymentsMessageHandler>,
5355
Arc<TestCustomMessageHandler>
5456
>,
5557
custom_message_handler: Arc<TestCustomMessageHandler>,
@@ -79,6 +81,14 @@ impl OffersMessageHandler for TestOffersMessageHandler {
7981
}
8082
}
8183

84+
struct TestAsyncPaymentsMessageHandler {}
85+
86+
impl AsyncPaymentsMessageHandler for TestAsyncPaymentsMessageHandler {
87+
fn handle_message(&self, _message: AsyncPaymentsMessage, _responder: Option<Responder>) -> ResponseInstruction<AsyncPaymentsMessage> {
88+
ResponseInstruction::NoResponse
89+
}
90+
}
91+
8292
#[derive(Clone, Debug, PartialEq)]
8393
enum TestCustomMessage {
8494
Ping,
@@ -249,18 +259,19 @@ fn create_nodes_using_cfgs(cfgs: Vec<MessengerCfg>) -> Vec<MessengerNode> {
249259
DefaultMessageRouter::new(network_graph.clone(), entropy_source.clone())
250260
);
251261
let offers_message_handler = Arc::new(TestOffersMessageHandler {});
262+
let async_payments_message_handler = Arc::new(TestAsyncPaymentsMessageHandler {});
252263
let custom_message_handler = Arc::new(TestCustomMessageHandler::new());
253264
let messenger = if cfg.intercept_offline_peer_oms {
254265
OnionMessenger::new_with_offline_peer_interception(
255266
entropy_source.clone(), node_signer.clone(), logger.clone(),
256267
node_id_lookup, message_router, offers_message_handler,
257-
custom_message_handler.clone()
268+
async_payments_message_handler, custom_message_handler.clone()
258269
)
259270
} else {
260271
OnionMessenger::new(
261272
entropy_source.clone(), node_signer.clone(), logger.clone(),
262273
node_id_lookup, message_router, offers_message_handler,
263-
custom_message_handler.clone()
274+
async_payments_message_handler, custom_message_handler.clone()
264275
)
265276
};
266277
nodes.push(MessengerNode {

0 commit comments

Comments
 (0)