Skip to content

Commit

Permalink
Defer initial packet payload decryption until after accept
Browse files Browse the repository at this point in the history
Reduces the amount of work done for connection attempts that will be
refused or ignored when the application layer can do so
cheaply, e.g. using a blocked IP list.
  • Loading branch information
Ralith committed Apr 4, 2024
1 parent e28a7f2 commit 23d3c96
Showing 1 changed file with 23 additions and 12 deletions.
35 changes: 23 additions & 12 deletions quinn-proto/src/endpoint.rs
Original file line number Diff line number Diff line change
Expand Up @@ -427,7 +427,7 @@ impl Endpoint {
&mut self,
addresses: FourTuple,
ecn: Option<EcnCodepoint>,
mut packet: Packet,
packet: Packet,
rest: Option<BytesMut>,
crypto: Keys,
buf: &mut BytesMut,
Expand All @@ -445,16 +445,6 @@ impl Endpoint {
};
let packet_number = packet_number.expand(0);

if crypto
.packet
.remote
.decrypt(packet_number, &packet.header_data, &mut packet.payload)
.is_err()
{
debug!(packet_number, "failed to authenticate initial packet");
return None;
};

if !packet.reserved_bits_valid() {
debug!("dropping connection attempt with invalid reserved bits");
return None;
Expand Down Expand Up @@ -508,7 +498,7 @@ impl Endpoint {
/// Attempt to accept this incoming connection (an error may still occur)
pub fn accept(
&mut self,
incoming: Incoming,
mut incoming: Incoming,
now: Instant,
buf: &mut BytesMut,
) -> Result<(ConnectionHandle, Connection), AcceptError> {
Expand All @@ -529,6 +519,27 @@ impl Endpoint {

let server_config = self.server_config.as_ref().unwrap().clone();

if incoming
.crypto
.packet
.remote
.decrypt(
incoming.packet_number,
&incoming.packet.header_data,
&mut incoming.packet.payload,
)
.is_err()
{
debug!(
packet_number = incoming.packet_number,
"failed to authenticate initial packet"
);
return Err(AcceptError {
cause: TransportError::PROTOCOL_VIOLATION("authentication failed").into(),
response: None,
});
};

let ch = ConnectionHandle(self.connections.vacant_key());
let loc_cid = self.new_cid(ch);
let mut params = TransportParameters::new(
Expand Down

0 comments on commit 23d3c96

Please sign in to comment.