Struct openssl::ssl::SslMode
[−]
pub struct SslMode { /* fields omitted */ }
Options controlling the behavior of an SslContext
.
Methods
impl SslMode
const ENABLE_PARTIAL_WRITE: SslMode
ENABLE_PARTIAL_WRITE: SslMode = SslMode{bits: ffi::SSL_MODE_ENABLE_PARTIAL_WRITE,}
Enables "short writes".
Normally, a write in OpenSSL will always write out all of the requested data, even if it requires more than one TLS record or write to the underlying stream. This option will cause a write to return after writing a single TLS record instead.
const ACCEPT_MOVING_WRITE_BUFFER: SslMode
ACCEPT_MOVING_WRITE_BUFFER: SslMode = SslMode{bits: ffi::SSL_MODE_ACCEPT_MOVING_WRITE_BUFFER,}
Disables a check that the data buffer has not moved between calls when operating in a nonblocking context.
const AUTO_RETRY: SslMode
AUTO_RETRY: SslMode = SslMode{bits: ffi::SSL_MODE_AUTO_RETRY,}
Enables automatic retries after TLS session events such as renegotiations or heartbeats.
By default, OpenSSL will return a WantRead
error after a renegotiation or heartbeat.
This option will cause OpenSSL to automatically continue processing the requested
operation instead.
Note that SslStream::read
and SslStream::write
will automatically retry regardless
of the state of this option. It only affects SslStream::ssl_read
and
SslStream::ssl_write
.
const NO_AUTO_CHAIN: SslMode
NO_AUTO_CHAIN: SslMode = SslMode{bits: ffi::SSL_MODE_NO_AUTO_CHAIN,}
Disables automatic chain building when verifying a peer's certificate.
TLS peers are responsible for sending the entire certificate chain from the leaf to a trusted root, but some will incorrectly not do so. OpenSSL will try to build the chain out of certificates it knows of, and this option will disable that behavior.
const RELEASE_BUFFERS: SslMode
RELEASE_BUFFERS: SslMode = SslMode{bits: ffi::SSL_MODE_RELEASE_BUFFERS,}
Release memory buffers when the session does not need them.
This saves ~34 KiB of memory for idle streams.
const SEND_FALLBACK_SCSV: SslMode
SEND_FALLBACK_SCSV: SslMode = SslMode{bits: ffi::SSL_MODE_SEND_FALLBACK_SCSV,}
Sends the fake TLS_FALLBACK_SCSV
cipher suite in the ClientHello message of a
handshake.
This should only be enabled if a client has failed to connect to a server which attempted to downgrade the protocol version of the session.
Do not use this unless you know what you're doing!
fn empty() -> SslMode
Returns an empty set of flags.
fn all() -> SslMode
Returns the set containing all flags.
fn bits(&self) -> c_long
Returns the raw value of the flags currently stored.
fn from_bits(bits: c_long) -> Option<SslMode>
Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.
fn from_bits_truncate(bits: c_long) -> SslMode
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
fn is_empty(&self) -> bool
Returns true
if no flags are currently stored.
fn is_all(&self) -> bool
Returns true
if all flags are currently set.
fn intersects(&self, other: SslMode) -> bool
Returns true
if there are flags common to both self
and other
.
fn contains(&self, other: SslMode) -> bool
Returns true
all of the flags in other
are contained within self
.
fn insert(&mut self, other: SslMode)
Inserts the specified flags in-place.
fn remove(&mut self, other: SslMode)
Removes the specified flags in-place.
fn toggle(&mut self, other: SslMode)
Toggles the specified flags in-place.
fn set(&mut self, other: SslMode, value: bool)
Inserts or removes the specified flags depending on the passed value.
Trait Implementations
impl Copy for SslMode
impl PartialEq for SslMode
fn eq(&self, __arg_0: &SslMode) -> bool
This method tests for self
and other
values to be equal, and is used by ==
. Read more
fn ne(&self, __arg_0: &SslMode) -> bool
This method tests for !=
.
impl Eq for SslMode
impl Clone for SslMode
fn clone(&self) -> SslMode
Returns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)
1.0.0[src]
Performs copy-assignment from source
. Read more
impl PartialOrd for SslMode
fn partial_cmp(&self, __arg_0: &SslMode) -> Option<Ordering>
This method returns an ordering between self
and other
values if one exists. Read more
fn lt(&self, __arg_0: &SslMode) -> bool
This method tests less than (for self
and other
) and is used by the <
operator. Read more
fn le(&self, __arg_0: &SslMode) -> bool
This method tests less than or equal to (for self
and other
) and is used by the <=
operator. Read more
fn gt(&self, __arg_0: &SslMode) -> bool
This method tests greater than (for self
and other
) and is used by the >
operator. Read more
fn ge(&self, __arg_0: &SslMode) -> bool
This method tests greater than or equal to (for self
and other
) and is used by the >=
operator. Read more
impl Ord for SslMode
fn cmp(&self, __arg_0: &SslMode) -> Ordering
This method returns an Ordering
between self
and other
. Read more
fn max(self, other: Self) -> Self
1.22.0[src]
Compares and returns the maximum of two values. Read more
fn min(self, other: Self) -> Self
1.22.0[src]
Compares and returns the minimum of two values. Read more
impl Hash for SslMode
fn hash<__H: Hasher>(&self, __arg_0: &mut __H)
Feeds this value into the given [Hasher
]. Read more
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher,
1.3.0[src]
H: Hasher,
Feeds a slice of this type into the given [Hasher
]. Read more
impl Debug for SslMode
impl Binary for SslMode
impl Octal for SslMode
impl LowerHex for SslMode
impl UpperHex for SslMode
impl BitOr for SslMode
type Output = SslMode
The resulting type after applying the |
operator.
fn bitor(self, other: SslMode) -> SslMode
Returns the union of the two sets of flags.
impl BitOrAssign for SslMode
fn bitor_assign(&mut self, other: SslMode)
Adds the set of flags.
impl BitXor for SslMode
type Output = SslMode
The resulting type after applying the ^
operator.
fn bitxor(self, other: SslMode) -> SslMode
Returns the left flags, but with all the right flags toggled.
impl BitXorAssign for SslMode
fn bitxor_assign(&mut self, other: SslMode)
Toggles the set of flags.
impl BitAnd for SslMode
type Output = SslMode
The resulting type after applying the &
operator.
fn bitand(self, other: SslMode) -> SslMode
Returns the intersection between the two sets of flags.
impl BitAndAssign for SslMode
fn bitand_assign(&mut self, other: SslMode)
Disables all flags disabled in the set.
impl Sub for SslMode
type Output = SslMode
The resulting type after applying the -
operator.
fn sub(self, other: SslMode) -> SslMode
Returns the set difference of the two sets of flags.
impl SubAssign for SslMode
fn sub_assign(&mut self, other: SslMode)
Disables all flags enabled in the set.
impl Not for SslMode
type Output = SslMode
The resulting type after applying the !
operator.
fn not(self) -> SslMode
Returns the complement of this set of flags.
impl Extend<SslMode> for SslMode
fn extend<T: IntoIterator<Item = SslMode>>(&mut self, iterator: T)
Extends a collection with the contents of an iterator. Read more
impl FromIterator<SslMode> for SslMode
fn from_iter<T: IntoIterator<Item = SslMode>>(iterator: T) -> SslMode
Creates a value from an iterator. Read more