tokio_quiche/quic/connection/id.rs
1// Copyright (C) 2025, Cloudflare, Inc.
2// All rights reserved.
3//
4// Redistribution and use in source and binary forms, with or without
5// modification, are permitted provided that the following conditions are
6// met:
7//
8// * Redistributions of source code must retain the above copyright notice,
9// this list of conditions and the following disclaimer.
10//
11// * Redistributions in binary form must reproduce the above copyright
12// notice, this list of conditions and the following disclaimer in the
13// documentation and/or other materials provided with the distribution.
14//
15// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
16// IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
17// THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
18// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
19// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
20// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
21// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
22// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
23// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
24// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26
27use quiche::ConnectionId;
28
29use crate::QuicResult;
30
31/// A customizable generator to derive and verify QUIC connection IDs.
32///
33/// For QUIC servers, it can be useful to encode additional information in the
34/// source connection ID. This trait allows users to implement their own logic
35/// for that purpose. The crate also provides [`SimpleConnectionIdGenerator`]
36/// if no such customization is needed.
37///
38/// Clients currently can't configure a [`ConnectionIdGenerator`] and always use
39/// the [`SimpleConnectionIdGenerator`].
40pub trait ConnectionIdGenerator<'a>: Send + 'static {
41 /// Creates a new [`ConnectionId`] according to the generator's logic.
42 ///
43 /// The `socket_cookie` is propagated unchanged from the
44 /// [`QuicListener`](crate::socket::QuicListener) that received the
45 /// connection.
46 fn new_connection_id(&self, socket_cookie: u64) -> ConnectionId<'a>;
47
48 /// Verifies whether `cid` was generated by this [`ConnectionIdGenerator`].
49 ///
50 /// `socket_cookie` matches the value that would have been passed to
51 /// `new_connection_id` calls. The method should return an [`Err`] variant
52 /// if the connection ID can't be verified.
53 fn verify_connection_id(
54 &self, socket_cookie: u64, cid: &ConnectionId,
55 ) -> QuicResult<()>;
56}
57
58/// A [`ConnectionIdGenerator`] which creates random 20-byte connection IDs.
59///
60/// Random bytes are pulled directly from the operating system to create an ID.
61/// Any `socket_cookie` value is ignored.
62#[derive(Debug, Clone, Default)]
63pub struct SimpleConnectionIdGenerator;
64
65impl ConnectionIdGenerator<'static> for SimpleConnectionIdGenerator {
66 fn new_connection_id(&self, _socket_cookie: u64) -> ConnectionId<'static> {
67 let mut buf = vec![0; 20];
68 boring::rand::rand_bytes(&mut buf).unwrap();
69
70 ConnectionId::from_vec(buf)
71 }
72
73 /// Performs no verification, because this generator can create
74 /// any valid connection ID.
75 fn verify_connection_id(
76 &self, _socket_cookie: u64, _cid: &ConnectionId<'_>,
77 ) -> QuicResult<()> {
78 Ok(())
79 }
80}