#[non_exhaustive]pub enum PeerMisbehaved {
Show 74 variants
AttemptedDowngradeToTls12WhenTls13IsSupported,
BadCertChainExtensions,
DisallowedEncryptedExtension,
DuplicateClientHelloExtensions,
DuplicateEncryptedExtensions,
DuplicateHelloRetryRequestExtensions,
DuplicateNewSessionTicketExtensions,
DuplicateServerHelloExtensions,
DuplicateServerNameTypes,
EarlyDataAttemptedInSecondClientHello,
EarlyDataExtensionWithoutResumption,
EarlyDataOfferedWithVariedCipherSuite,
HandshakeHashVariedAfterRetry,
IllegalHelloRetryRequestWithEmptyCookie,
IllegalHelloRetryRequestWithNoChanges,
IllegalHelloRetryRequestWithOfferedGroup,
IllegalHelloRetryRequestWithUnofferedCipherSuite,
IllegalHelloRetryRequestWithUnofferedNamedGroup,
IllegalHelloRetryRequestWithUnsupportedVersion,
IllegalHelloRetryRequestWithWrongSessionId,
IllegalHelloRetryRequestWithInvalidEch,
IllegalMiddleboxChangeCipherSpec,
IllegalTlsInnerPlaintext,
IncorrectBinder,
InvalidCertCompression,
InvalidMaxEarlyDataSize,
InvalidKeyShare,
KeyEpochWithPendingFragment,
KeyUpdateReceivedInQuicConnection,
MessageInterleavedWithHandshakeMessage,
MissingBinderInPskExtension,
MissingKeyShare,
MissingPskModesExtension,
MissingQuicTransportParameters,
OfferedDuplicateCertificateCompressions,
OfferedDuplicateKeyShares,
OfferedEarlyDataWithOldProtocolVersion,
OfferedEmptyApplicationProtocol,
OfferedIncorrectCompressions,
PskExtensionMustBeLast,
PskExtensionWithMismatchedIdsAndBinders,
RefusedToFollowHelloRetryRequest,
RejectedEarlyDataInterleavedWithHandshakeMessage,
ResumptionAttemptedWithVariedEms,
ResumptionOfferedWithVariedCipherSuite,
ResumptionOfferedWithVariedEms,
ResumptionOfferedWithIncompatibleCipherSuite,
SelectedDifferentCipherSuiteAfterRetry,
SelectedInvalidPsk,
SelectedTls12UsingTls13VersionExtension,
SelectedUnofferedApplicationProtocol,
SelectedUnofferedCertCompression,
SelectedUnofferedCipherSuite,
SelectedUnofferedCompression,
SelectedUnofferedKxGroup,
SelectedUnofferedPsk,
SelectedUnusableCipherSuiteForVersion,
ServerHelloMustOfferUncompressedEcPoints,
ServerNameDifferedOnRetry,
ServerNameMustContainOneHostName,
SignedKxWithWrongAlgorithm,
SignedHandshakeWithUnadvertisedSigScheme,
TooManyEmptyFragments,
TooManyKeyUpdateRequests,
TooManyRenegotiationRequests,
TooManyWarningAlertsReceived,
TooMuchEarlyDataReceived,
UnexpectedCleartextExtension,
UnsolicitedCertExtension,
UnsolicitedEncryptedExtension,
UnsolicitedSctList,
UnsolicitedServerHelloExtension,
WrongGroupForKeyShare,
UnsolicitedEchExtension,
}
Expand description
The set of cases where we failed to make a connection because we thought the peer was misbehaving.
This is non_exhaustive
: we might add or stop using items here in minor
versions. We also don’t document what they mean. Generally a user of
rustls shouldn’t vary its behaviour on these error codes, and there is
nothing it can do to improve matters.
Please file a bug against rustls if you see Error::PeerMisbehaved
in
the wild.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
AttemptedDowngradeToTls12WhenTls13IsSupported
BadCertChainExtensions
DisallowedEncryptedExtension
DuplicateClientHelloExtensions
DuplicateEncryptedExtensions
DuplicateHelloRetryRequestExtensions
DuplicateNewSessionTicketExtensions
DuplicateServerHelloExtensions
DuplicateServerNameTypes
EarlyDataAttemptedInSecondClientHello
EarlyDataExtensionWithoutResumption
EarlyDataOfferedWithVariedCipherSuite
HandshakeHashVariedAfterRetry
IllegalHelloRetryRequestWithEmptyCookie
IllegalHelloRetryRequestWithNoChanges
IllegalHelloRetryRequestWithOfferedGroup
IllegalHelloRetryRequestWithUnofferedCipherSuite
IllegalHelloRetryRequestWithUnofferedNamedGroup
IllegalHelloRetryRequestWithUnsupportedVersion
IllegalHelloRetryRequestWithWrongSessionId
IllegalHelloRetryRequestWithInvalidEch
IllegalMiddleboxChangeCipherSpec
IllegalTlsInnerPlaintext
IncorrectBinder
InvalidCertCompression
InvalidMaxEarlyDataSize
KeyEpochWithPendingFragment
KeyUpdateReceivedInQuicConnection
MessageInterleavedWithHandshakeMessage
MissingBinderInPskExtension
MissingPskModesExtension
MissingQuicTransportParameters
OfferedDuplicateCertificateCompressions
OfferedEarlyDataWithOldProtocolVersion
OfferedEmptyApplicationProtocol
OfferedIncorrectCompressions
PskExtensionMustBeLast
PskExtensionWithMismatchedIdsAndBinders
RefusedToFollowHelloRetryRequest
RejectedEarlyDataInterleavedWithHandshakeMessage
ResumptionAttemptedWithVariedEms
ResumptionOfferedWithVariedCipherSuite
ResumptionOfferedWithVariedEms
ResumptionOfferedWithIncompatibleCipherSuite
SelectedDifferentCipherSuiteAfterRetry
SelectedInvalidPsk
SelectedTls12UsingTls13VersionExtension
SelectedUnofferedApplicationProtocol
SelectedUnofferedCertCompression
SelectedUnofferedCipherSuite
SelectedUnofferedCompression
SelectedUnofferedKxGroup
SelectedUnofferedPsk
SelectedUnusableCipherSuiteForVersion
ServerHelloMustOfferUncompressedEcPoints
ServerNameDifferedOnRetry
ServerNameMustContainOneHostName
SignedKxWithWrongAlgorithm
SignedHandshakeWithUnadvertisedSigScheme
TooManyEmptyFragments
TooManyKeyUpdateRequests
TooManyRenegotiationRequests
TooManyWarningAlertsReceived
TooMuchEarlyDataReceived
UnexpectedCleartextExtension
UnsolicitedCertExtension
UnsolicitedEncryptedExtension
UnsolicitedSctList
UnsolicitedServerHelloExtension
UnsolicitedEchExtension
Trait Implementations§
Source§impl Clone for PeerMisbehaved
impl Clone for PeerMisbehaved
Source§fn clone(&self) -> PeerMisbehaved
fn clone(&self) -> PeerMisbehaved
Returns a copy of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl Debug for PeerMisbehaved
impl Debug for PeerMisbehaved
Source§impl From<PeerMisbehaved> for Error
impl From<PeerMisbehaved> for Error
Source§fn from(e: PeerMisbehaved) -> Self
fn from(e: PeerMisbehaved) -> Self
Converts to this type from the input type.
Source§impl PartialEq for PeerMisbehaved
impl PartialEq for PeerMisbehaved
impl StructuralPartialEq for PeerMisbehaved
Auto Trait Implementations§
impl Freeze for PeerMisbehaved
impl RefUnwindSafe for PeerMisbehaved
impl Send for PeerMisbehaved
impl Sync for PeerMisbehaved
impl Unpin for PeerMisbehaved
impl UnwindSafe for PeerMisbehaved
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 1 byte
Size for each variant:
AttemptedDowngradeToTls12WhenTls13IsSupported
: 0 bytesBadCertChainExtensions
: 0 bytesDisallowedEncryptedExtension
: 0 bytesDuplicateClientHelloExtensions
: 0 bytesDuplicateEncryptedExtensions
: 0 bytesDuplicateHelloRetryRequestExtensions
: 0 bytesDuplicateNewSessionTicketExtensions
: 0 bytesDuplicateServerHelloExtensions
: 0 bytesDuplicateServerNameTypes
: 0 bytesEarlyDataAttemptedInSecondClientHello
: 0 bytesEarlyDataExtensionWithoutResumption
: 0 bytesEarlyDataOfferedWithVariedCipherSuite
: 0 bytesHandshakeHashVariedAfterRetry
: 0 bytesIllegalHelloRetryRequestWithEmptyCookie
: 0 bytesIllegalHelloRetryRequestWithNoChanges
: 0 bytesIllegalHelloRetryRequestWithOfferedGroup
: 0 bytesIllegalHelloRetryRequestWithUnofferedCipherSuite
: 0 bytesIllegalHelloRetryRequestWithUnofferedNamedGroup
: 0 bytesIllegalHelloRetryRequestWithUnsupportedVersion
: 0 bytesIllegalHelloRetryRequestWithWrongSessionId
: 0 bytesIllegalHelloRetryRequestWithInvalidEch
: 0 bytesIllegalMiddleboxChangeCipherSpec
: 0 bytesIllegalTlsInnerPlaintext
: 0 bytesIncorrectBinder
: 0 bytesInvalidCertCompression
: 0 bytesInvalidMaxEarlyDataSize
: 0 bytesInvalidKeyShare
: 0 bytesKeyEpochWithPendingFragment
: 0 bytesKeyUpdateReceivedInQuicConnection
: 0 bytesMessageInterleavedWithHandshakeMessage
: 0 bytesMissingBinderInPskExtension
: 0 bytesMissingKeyShare
: 0 bytesMissingPskModesExtension
: 0 bytesMissingQuicTransportParameters
: 0 bytesOfferedDuplicateCertificateCompressions
: 0 bytesOfferedDuplicateKeyShares
: 0 bytesOfferedEarlyDataWithOldProtocolVersion
: 0 bytesOfferedEmptyApplicationProtocol
: 0 bytesOfferedIncorrectCompressions
: 0 bytesPskExtensionMustBeLast
: 0 bytesPskExtensionWithMismatchedIdsAndBinders
: 0 bytesRefusedToFollowHelloRetryRequest
: 0 bytesRejectedEarlyDataInterleavedWithHandshakeMessage
: 0 bytesResumptionAttemptedWithVariedEms
: 0 bytesResumptionOfferedWithVariedCipherSuite
: 0 bytesResumptionOfferedWithVariedEms
: 0 bytesResumptionOfferedWithIncompatibleCipherSuite
: 0 bytesSelectedDifferentCipherSuiteAfterRetry
: 0 bytesSelectedInvalidPsk
: 0 bytesSelectedTls12UsingTls13VersionExtension
: 0 bytesSelectedUnofferedApplicationProtocol
: 0 bytesSelectedUnofferedCertCompression
: 0 bytesSelectedUnofferedCipherSuite
: 0 bytesSelectedUnofferedCompression
: 0 bytesSelectedUnofferedKxGroup
: 0 bytesSelectedUnofferedPsk
: 0 bytesSelectedUnusableCipherSuiteForVersion
: 0 bytesServerHelloMustOfferUncompressedEcPoints
: 0 bytesServerNameDifferedOnRetry
: 0 bytesServerNameMustContainOneHostName
: 0 bytesSignedKxWithWrongAlgorithm
: 0 bytesSignedHandshakeWithUnadvertisedSigScheme
: 0 bytesTooManyEmptyFragments
: 0 bytesTooManyKeyUpdateRequests
: 0 bytesTooManyRenegotiationRequests
: 0 bytesTooManyWarningAlertsReceived
: 0 bytesTooMuchEarlyDataReceived
: 0 bytesUnexpectedCleartextExtension
: 0 bytesUnsolicitedCertExtension
: 0 bytesUnsolicitedEncryptedExtension
: 0 bytesUnsolicitedSctList
: 0 bytesUnsolicitedServerHelloExtension
: 0 bytesWrongGroupForKeyShare
: 0 bytesUnsolicitedEchExtension
: 0 bytes