Skip to content

Commit

Permalink
fix(dht): optimisation, no decrypt if public key dest doesn't match (#…
Browse files Browse the repository at this point in the history
…4131)

Description
---
Don't attempt decryption if the public key destination does not match the node identity

Motivation and Context
---
Decryption is not necessary if the destination public key is specified and does not match.

How Has This Been Tested?
---
Manually, Memorynet and existing tests that check this case already pass.
  • Loading branch information
sdbondi authored May 25, 2022
1 parent 3773bba commit 987972c
Showing 1 changed file with 19 additions and 0 deletions.
19 changes: 19 additions & 0 deletions comms/dht/src/inbound/decryption.rs
Original file line number Diff line number Diff line change
Expand Up @@ -197,6 +197,7 @@ where S: Service<DecryptedDhtMessage, Response = (), Error = PipelineError>
}
}

#[allow(clippy::too_many_lines)]
async fn validate_and_decrypt_message(
node_identity: Arc<NodeIdentity>,
message: DhtInboundMessage,
Expand All @@ -220,6 +221,24 @@ where S: Service<DecryptedDhtMessage, Response = (), Error = PipelineError>
return Err(DecryptionError::EncryptedMessageNoDestination);
}

if !message.dht_header.destination.is_unknown() &&
message
.dht_header
.destination
.public_key()
.map(|pk| pk != node_identity.public_key())
.unwrap_or(false)
{
debug!(
target: LOG_TARGET,
"Encrypted message (source={}, {}) not destined for this peer. Passing to next service (Trace: {})",
message.source_peer.node_id,
message.dht_header.message_tag,
message.tag
);
return Ok(DecryptedDhtMessage::failed(message));
}

let e_pk = dht_header
.ephemeral_public_key
.as_ref()
Expand Down

0 comments on commit 987972c

Please sign in to comment.