Skip to content

Commit ad0edff

Browse files
committed
f - Include short_channel_id in temporary_node_failure
1 parent 2745460 commit ad0edff

File tree

2 files changed

+7
-3
lines changed

2 files changed

+7
-3
lines changed

lightning/src/ln/onion_route_tests.rs

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -373,7 +373,7 @@ fn test_onion_failure() {
373373
let session_priv = SecretKey::from_slice(&[3; 32]).unwrap();
374374
let onion_keys = onion_utils::construct_onion_keys(&Secp256k1::new(), &route.paths[0], &session_priv).unwrap();
375375
msg.reason = onion_utils::build_first_hop_failure_packet(&onion_keys[0].shared_secret[..], NODE|2, &[0;0]);
376-
}, ||{}, true, Some(NODE|2), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][0].pubkey, is_permanent: false}), None);
376+
}, ||{}, true, Some(NODE|2), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][0].pubkey, is_permanent: false}), Some(route.paths[0][0].short_channel_id));
377377

378378
// final node failure
379379
run_onion_failure_test_with_fail_intercept("temporary_node_failure", 200, &nodes, &route, &payment_hash, &payment_secret, |_msg| {}, |msg| {
@@ -383,7 +383,7 @@ fn test_onion_failure() {
383383
msg.reason = onion_utils::build_first_hop_failure_packet(&onion_keys[1].shared_secret[..], NODE|2, &[0;0]);
384384
}, ||{
385385
nodes[2].node.fail_htlc_backwards(&payment_hash);
386-
}, true, Some(NODE|2), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][1].pubkey, is_permanent: false}), None);
386+
}, true, Some(NODE|2), Some(NetworkUpdate::NodeFailure{node_id: route.paths[0][1].pubkey, is_permanent: false}), Some(route.paths[0][1].short_channel_id));
387387
let (_, payment_hash, payment_secret) = get_payment_preimage_hash!(nodes[2]);
388388

389389
// intermediate node failure

lightning/src/ln/onion_utils.rs

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -386,7 +386,11 @@ pub(super) fn process_onion_failure<T: secp256k1::Signing, L: Deref>(secp_ctx: &
386386
let mut short_channel_id = None;
387387

388388
if error_code & NODE == NODE {
389-
network_update = Some(NetworkUpdate::NodeFailure { node_id: route_hop.pubkey, is_permanent: error_code & PERM == PERM });
389+
let is_permanent = error_code & PERM == PERM;
390+
network_update = Some(NetworkUpdate::NodeFailure { node_id: route_hop.pubkey, is_permanent });
391+
if !is_permanent {
392+
short_channel_id = Some(route_hop.short_channel_id);
393+
}
390394
}
391395
else if error_code & PERM == PERM {
392396
if !payment_failed {

0 commit comments

Comments
 (0)