Skip to content

Commit

Permalink
Add v1 only detection
Browse files Browse the repository at this point in the history
  • Loading branch information
nyonson committed Oct 3, 2024
1 parent fdb97db commit 5c8779a
Showing 1 changed file with 23 additions and 3 deletions.
26 changes: 23 additions & 3 deletions protocol/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -976,7 +976,11 @@ impl<'a> Handshake<'a> {
#[cfg(feature = "std")]
#[derive(Debug)]
pub enum ProtocolError {
/// Wrap all IO errors.
Io(std::io::Error),
/// Remote likely only supports V1 protocol.
IncompatibleProtocol(std::io::Error),
/// Internal protocol specific errors.
Internal(Error),
}

Expand All @@ -1001,8 +1005,11 @@ impl std::error::Error for ProtocolError {}
impl fmt::Display for ProtocolError {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
match self {
ProtocolError::Io(e) => write!(f, "IO error: {:?}", e),
ProtocolError::Internal(e) => write!(f, "Internal error: {:?}", e),
ProtocolError::Io(e) => write!(f, "IO error: {:?}.", e),
ProtocolError::Internal(e) => write!(f, "Internal error: {:?}.", e),
ProtocolError::IncompatibleProtocol(e) => {
write!(f, "Remote likely only supports V1 protocol: {:?}.", e)
}
}
}
}
Expand Down Expand Up @@ -1040,6 +1047,10 @@ where
/// A `Result` containing:
/// * `Ok(AsyncProtocol)`: An initialized protocol handler.
/// * `Err(ProtocolError)`: An error that occurred during the handshake.
///
/// # Errors
///
/// * `IncompatibleProtocol` - Indicates the remote probably only understands V1.
pub async fn new<'a>(
network: Network,
role: Role,
Expand All @@ -1061,7 +1072,16 @@ where

// Read remote's initial key.
let mut remote_ellswift_buffer = [0u8; 64];
reader.read_exact(&mut remote_ellswift_buffer).await?;
// Try to detect errors which likely mean the remote doesn't understand
// the V2 protocol and the caller should re-attempt on V1 if they want.
if let Err(e) = reader.read_exact(&mut remote_ellswift_buffer).await {
return match e.kind() {
std::io::ErrorKind::UnexpectedEof | std::io::ErrorKind::ConnectionReset => {
Err(ProtocolError::IncompatibleProtocol(e))
}
_ => Err(ProtocolError::Io(e)),
};
}

let num_version_packet_bytes = PacketWriter::required_packet_allocation(&VERSION_CONTENT);
let num_decoy_packets_bytes: usize = match decoys {
Expand Down

0 comments on commit 5c8779a

Please sign in to comment.