Skip to content

Commit cfb8030

Browse files
committed
f - Always set short_channel_id for NODE errors
1 parent 9520445 commit cfb8030

File tree

2 files changed

+5
-7
lines changed

2 files changed

+5
-7
lines changed

lightning/src/ln/onion_route_tests.rs

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -393,7 +393,7 @@ fn test_onion_failure() {
393393
let session_priv = SecretKey::from_slice(&[3; 32]).unwrap();
394394
let onion_keys = onion_utils::construct_onion_keys(&Secp256k1::new(), &route.paths[0], &session_priv).unwrap();
395395
msg.reason = onion_utils::build_first_hop_failure_packet(&onion_keys[0].shared_secret[..], PERM|NODE|2, &[0;0]);
396-
}, ||{}, true, Some(PERM|NODE|2), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][0].pubkey, is_permanent: true}), None);
396+
}, ||{}, true, Some(PERM|NODE|2), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][0].pubkey, is_permanent: true}), Some(route.paths[0][0].short_channel_id));
397397

398398
// final node failure
399399
run_onion_failure_test_with_fail_intercept("permanent_node_failure", 200, &nodes, &route, &payment_hash, &payment_secret, |_msg| {}, |msg| {
@@ -402,7 +402,7 @@ fn test_onion_failure() {
402402
msg.reason = onion_utils::build_first_hop_failure_packet(&onion_keys[1].shared_secret[..], PERM|NODE|2, &[0;0]);
403403
}, ||{
404404
nodes[2].node.fail_htlc_backwards(&payment_hash);
405-
}, false, Some(PERM|NODE|2), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][1].pubkey, is_permanent: true}), None);
405+
}, false, Some(PERM|NODE|2), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][1].pubkey, is_permanent: true}), Some(route.paths[0][1].short_channel_id));
406406
let (_, payment_hash, payment_secret) = get_payment_preimage_hash!(nodes[2]);
407407

408408
// intermediate node failure
@@ -414,7 +414,7 @@ fn test_onion_failure() {
414414
msg.reason = onion_utils::build_first_hop_failure_packet(&onion_keys[0].shared_secret[..], PERM|NODE|3, &[0;0]);
415415
}, ||{
416416
nodes[2].node.fail_htlc_backwards(&payment_hash);
417-
}, true, Some(PERM|NODE|3), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][0].pubkey, is_permanent: true}), None);
417+
}, true, Some(PERM|NODE|3), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][0].pubkey, is_permanent: true}), Some(route.paths[0][0].short_channel_id));
418418

419419
// final node failure
420420
run_onion_failure_test_with_fail_intercept("required_node_feature_missing", 200, &nodes, &route, &payment_hash, &payment_secret, |_msg| {}, |msg| {
@@ -423,7 +423,7 @@ fn test_onion_failure() {
423423
msg.reason = onion_utils::build_first_hop_failure_packet(&onion_keys[1].shared_secret[..], PERM|NODE|3, &[0;0]);
424424
}, ||{
425425
nodes[2].node.fail_htlc_backwards(&payment_hash);
426-
}, false, Some(PERM|NODE|3), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][1].pubkey, is_permanent: true}), None);
426+
}, false, Some(PERM|NODE|3), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][1].pubkey, is_permanent: true}), Some(route.paths[0][1].short_channel_id));
427427
let (_, payment_hash, payment_secret) = get_payment_preimage_hash!(nodes[2]);
428428

429429
// Our immediate peer sent UpdateFailMalformedHTLC because it couldn't understand the onion in

lightning/src/ln/onion_utils.rs

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -394,9 +394,7 @@ pub(super) fn process_onion_failure<T: secp256k1::Signing, L: Deref>(secp_ctx: &
394394
else if error_code & NODE == NODE {
395395
let is_permanent = error_code & PERM == PERM;
396396
network_update = Some(NetworkUpdate::NodeFailure { node_id: route_hop.pubkey, is_permanent });
397-
if !is_permanent {
398-
short_channel_id = Some(route_hop.short_channel_id);
399-
}
397+
short_channel_id = Some(route_hop.short_channel_id);
400398
}
401399
else if error_code & PERM == PERM {
402400
if !payment_failed {

0 commit comments

Comments
 (0)