1
0
mirror of https://github.com/fafhrd91/actix-net synced 2025-01-31 10:22:09 +01:00
actix-net/actix_tls/accept/rustls_0_23/reexports/struct.ServerConfig.html

169 lines
54 KiB
HTML
Raw Normal View History

<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta name="generator" content="rustdoc"><meta name="description" content="Common configuration for a set of server sessions."><title>ServerConfig in actix_tls::accept::rustls_0_23::reexports - Rust</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-46f98efaafac5295.ttf.woff2,FiraSans-Regular-018c141bf0843ffd.woff2,FiraSans-Medium-8f9a781e4970d388.woff2,SourceCodePro-Regular-562dcc5011b6de7d.ttf.woff2,SourceCodePro-Semibold-d899c5a5c4aeb14a.ttf.woff2".split(",").map(f=>`<link rel="preload" as="font" type="font/woff2" crossorigin href="../../../../static.files/${f}">`).join(""))</script><link rel="stylesheet" href="../../../../static.files/normalize-76eba96aa4d2e634.css"><link rel="stylesheet" href="../../../../static.files/rustdoc-b778ab399e080a4b.css"><meta name="rustdoc-vars" data-root-path="../../../../" data-static-root-path="../../../../static.files/" data-current-crate="actix_tls" data-themes="" data-resource-suffix="" data-rustdoc-version="1.83.0-nightly (7608018cb 2024-09-29)" data-channel="nightly" data-search-js="search-e056c65ede92db13.js" data-settings-js="settings-805db61a62df4bd2.js" ><script src="../../../../static.files/storage-1d39b6787ed640ff.js"></script><script defer src="sidebar-items.js"></script><script defer src="../../../../static.files/main-54bc299d2a5e4e43.js"></script><noscript><link rel="stylesheet" href="../../../../static.files/noscript-0111fcff984fae8f.css"></noscript><link rel="icon" href="https://actix.rs/favicon.ico"></head><body class="rustdoc struct"><!--[if lte IE 11]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><nav class="mobile-topbar"><button class="sidebar-menu-toggle" title="show sidebar"></button><a class="logo-container" href="../../../../actix_tls/index.html"><img src="https://actix.rs/img/logo.png" alt=""></a></nav><nav class="sidebar"><div class="sidebar-crate"><a class="logo-container" href="../../../../actix_tls/index.html"><img src="https://actix.rs/img/logo.png" alt="logo"></a><h2><a href="../../../../actix_tls/index.html">actix_<wbr>tls</a><span class="version">3.4.0</span></h2></div><div class="sidebar-elems"><section id="rustdoc-toc"><h2 class="location"><a href="#">Server<wbr>Config</a></h2><h3><a href="#">Sections</a></h3><ul class="block top-toc"><li><a href="#defaults" title="Defaults">Defaults</a></li></ul><h3><a href="#fields">Fields</a></h3><ul class="block structfield"><li><a href="#structfield.alpn_protocols" title="alpn_protocols">alpn_protocols</a></li><li><a href="#structfield.cert_compression_cache" title="cert_compression_cache">cert_compression_cache</a></li><li><a href="#structfield.cert_compressors" title="cert_compressors">cert_compressors</a></li><li><a href="#structfield.cert_decompressors" title="cert_decompressors">cert_decompressors</a></li><li><a href="#structfield.cert_resolver" title="cert_resolver">cert_resolver</a></li><li><a href="#structfield.enable_secret_extraction" title="enable_secret_extraction">enable_secret_extraction</a></li><li><a href="#structfield.ignore_client_order" title="ignore_client_order">ignore_client_order</a></li><li><a href="#structfield.key_log" title="key_log">key_log</a></li><li><a href="#structfield.max_early_data_size" title="max_early_data_size">max_early_data_size</a></li><li><a href="#structfield.max_fragment_size" title="max_fragment_size">max_fragment_size</a></li><li><a href="#structfield.send_half_rtt_data" title="send_half_rtt_data">send_half_rtt_data</a></li><li><a href="#structfield.send_tls13_tickets" title="send_tls13_tickets">send_tls13_tickets</a></li><li><a href="#structfield.session_storage" title="session_storage">session_storage</a></li><li><a href="#structfield.ticketer" title="ticketer">ticketer</a></li><li><a href="#structfield.time_provider" title="time_provider">time_provider</a></li></ul><h3><a href="#implementations">Method
pub ignore_client_order: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.bool.html">bool</a>,
pub max_fragment_size: <a class="enum" href="https://doc.rust-lang.org/nightly/core/option/enum.Option.html" title="enum core::option::Option">Option</a>&lt;<a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.usize.html">usize</a>&gt;,
pub session_storage: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn StoresServerSessions&gt;,
pub ticketer: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn ProducesTickets&gt;,
pub cert_resolver: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn ResolvesServerCert&gt;,
pub alpn_protocols: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html" title="struct alloc::vec::Vec">Vec</a>&lt;<a class="struct" href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html" title="struct alloc::vec::Vec">Vec</a>&lt;<a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.u8.html">u8</a>&gt;&gt;,
pub key_log: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn KeyLog&gt;,
pub enable_secret_extraction: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.bool.html">bool</a>,
pub max_early_data_size: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.u32.html">u32</a>,
pub send_half_rtt_data: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.bool.html">bool</a>,
pub send_tls13_tickets: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.usize.html">usize</a>,
pub time_provider: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn TimeProvider&gt;,
pub cert_compressors: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html" title="struct alloc::vec::Vec">Vec</a>&lt;&amp;'static dyn CertCompressor&gt;,
pub cert_compression_cache: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;CompressionCache&gt;,
pub cert_decompressors: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html" title="struct alloc::vec::Vec">Vec</a>&lt;&amp;'static dyn CertDecompressor&gt;,
<span class="comment">/* private fields */</span>
</details>}</code></pre><details class="toggle top-doc" open><summary class="hideme"><span>Expand description</span></summary><div class="docblock"><p>Common configuration for a set of server sessions.</p>
<p>Making one of these is cheap, though one of the inputs may be expensive: gathering trust roots
from the operating system to add to the <a href="crate::RootCertStore"><code>RootCertStore</code></a> passed to a <code>ClientCertVerifier</code>
builder may take on the order of a few hundred milliseconds.</p>
<p>These must be created via the <a href="struct.ServerConfig.html#method.builder" title="associated function actix_tls::accept::rustls_0_23::reexports::ServerConfig::builder"><code>ServerConfig::builder()</code></a> or <a href="struct.ServerConfig.html#method.builder_with_provider" title="associated function actix_tls::accept::rustls_0_23::reexports::ServerConfig::builder_with_provider"><code>ServerConfig::builder_with_provider()</code></a>
function.</p>
<h2 id="defaults"><a class="doc-anchor" href="#defaults">§</a>Defaults</h2>
<ul>
<li><a href="struct.ServerConfig.html#structfield.max_fragment_size" title="field actix_tls::accept::rustls_0_23::reexports::ServerConfig::max_fragment_size"><code>ServerConfig::max_fragment_size</code></a>: the default is <code>None</code> (meaning 16kB).</li>
<li><a href="struct.ServerConfig.html#structfield.session_storage" title="field actix_tls::accept::rustls_0_23::reexports::ServerConfig::session_storage"><code>ServerConfig::session_storage</code></a>: if the <code>std</code> feature is enabled, the default stores 256
sessions in memory. If the <code>std</code> feature is not enabled, the default is to not store any
sessions. In a no-std context, by enabling the <code>hashbrown</code> feature you may provide your
own <code>session_storage</code> using <a href="crate::server::handy::ServerSessionMemoryCache"><code>ServerSessionMemoryCache</code></a> and a <code>crate::lock::MakeMutex</code>
implementation.</li>
<li><a href="struct.ServerConfig.html#structfield.alpn_protocols" title="field actix_tls::accept::rustls_0_23::reexports::ServerConfig::alpn_protocols"><code>ServerConfig::alpn_protocols</code></a>: the default is empty no ALPN protocol is negotiated.</li>
<li><a href="struct.ServerConfig.html#structfield.key_log" title="field actix_tls::accept::rustls_0_23::reexports::ServerConfig::key_log"><code>ServerConfig::key_log</code></a>: key material is not logged.</li>
<li><a href="struct.ServerConfig.html#structfield.send_tls13_tickets" title="field actix_tls::accept::rustls_0_23::reexports::ServerConfig::send_tls13_tickets"><code>ServerConfig::send_tls13_tickets</code></a>: 4 tickets are sent.</li>
<li><a href="struct.ServerConfig.html#structfield.cert_compressors" title="field actix_tls::accept::rustls_0_23::reexports::ServerConfig::cert_compressors"><code>ServerConfig::cert_compressors</code></a>: depends on the crate features, see [<code>compress::default_cert_compressors()</code>].</li>
<li><a href="struct.ServerConfig.html#structfield.cert_compression_cache" title="field actix_tls::accept::rustls_0_23::reexports::ServerConfig::cert_compression_cache"><code>ServerConfig::cert_compression_cache</code></a>: caches the most recently used 4 compressions</li>
<li><a href="struct.ServerConfig.html#structfield.cert_decompressors" title="field actix_tls::accept::rustls_0_23::reexports::ServerConfig::cert_decompressors"><code>ServerConfig::cert_decompressors</code></a>: depends on the crate features, see [<code>compress::default_cert_decompressors()</code>].</li>
</ul>
</div></details><h2 id="fields" class="fields section-header">Fields<a href="#fields" class="anchor">§</a></h2><span id="structfield.ignore_client_order" class="structfield section-header"><a href="#structfield.ignore_client_order" class="anchor field">§</a><code>ignore_client_order: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.bool.html">bool</a></code></span><div class="docblock"><p>Ignore the clients ciphersuite order. Instead,
choose the top ciphersuite in the server list
which is supported by the client.</p>
</div><span id="structfield.max_fragment_size" class="structfield section-header"><a href="#structfield.max_fragment_size" class="anchor field">§</a><code>max_fragment_size: <a class="enum" href="https://doc.rust-lang.org/nightly/core/option/enum.Option.html" title="enum core::option::Option">Option</a>&lt;<a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.usize.html">usize</a>&gt;</code></span><div class="docblock"><p>The maximum size of plaintext input to be emitted in a single TLS record.
A value of None is equivalent to the <a href="https://datatracker.ietf.org/doc/html/rfc8446#section-5.1">TLS maximum</a> of 16 kB.</p>
<p>rustls enforces an arbitrary minimum of 32 bytes for this field.
Out of range values are reported as errors from <a href="crate::server::ServerConnection::new">ServerConnection::new</a>.</p>
<p>Setting this value to a little less than the TCP MSS may improve latency
for stream-y workloads.</p>
</div><span id="structfield.session_storage" class="structfield section-header"><a href="#structfield.session_storage" class="anchor field">§</a><code>session_storage: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn StoresServerSessions&gt;</code></span><div class="docblock"><p>How to store client sessions.</p>
</div><span id="structfield.ticketer" class="structfield section-header"><a href="#structfield.ticketer" class="anchor field">§</a><code>ticketer: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn ProducesTickets&gt;</code></span><div class="docblock"><p>How to produce tickets.</p>
</div><span id="structfield.cert_resolver" class="structfield section-header"><a href="#structfield.cert_resolver" class="anchor field">§</a><code>cert_resolver: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn ResolvesServerCert&gt;</code></span><div class="docblock"><p>How to choose a server cert and key. This is usually set by
[ConfigBuilder::with_single_cert] or [ConfigBuilder::with_cert_resolver].
For async applications, see also [Acceptor].</p>
</div><span id="structfield.alpn_protocols" class="structfield section-header"><a href="#structfield.alpn_protocols" class="anchor field">§</a><code>alpn_protocols: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html" title="struct alloc::vec::Vec">Vec</a>&lt;<a class="struct" href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html" title="struct alloc::vec::Vec">Vec</a>&lt;<a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.u8.html">u8</a>&gt;&gt;</code></span><div class="docblock"><p>Protocol names we support, most preferred first.
If empty we dont do ALPN at all.</p>
</div><span id="structfield.key_log" class="structfield section-header"><a href="#structfield.key_log" class="anchor field">§</a><code>key_log: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn KeyLog&gt;</code></span><div class="docblock"><p>How to output key material for debugging. The default
does nothing.</p>
</div><span id="structfield.enable_secret_extraction" class="structfield section-header"><a href="#structfield.enable_secret_extraction" class="anchor field">§</a><code>enable_secret_extraction: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.bool.html">bool</a></code></span><div class="docblock"><p>Allows traffic secrets to be extracted after the handshake,
e.g. for kTLS setup.</p>
</div><span id="structfield.max_early_data_size" class="structfield section-header"><a href="#structfield.max_early_data_size" class="anchor field">§</a><code>max_early_data_size: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.u32.html">u32</a></code></span><div class="docblock"><p>Amount of early data to accept for sessions created by
this config. Specify 0 to disable early data. The
default is 0.</p>
<p>Read the early data via [<code>ServerConnection::early_data</code>].</p>
<p>The units for this are <em>both</em> plaintext bytes, <em>and</em> ciphertext
bytes, depending on whether the server accepts a clients early_data
or not. It is therefore recommended to include some slop in
this value to account for the unknown amount of ciphertext
expansion in the latter case.</p>
</div><span id="structfield.send_half_rtt_data" class="structfield section-header"><a href="#structfield.send_half_rtt_data" class="anchor field">§</a><code>send_half_rtt_data: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.bool.html">bool</a></code></span><div class="docblock"><p>Whether the server should send “0.5RTT” data. This means the server
sends data after its first flight of handshake messages, without
waiting for the client to complete the handshake.</p>
<p>This can improve TTFB latency for either server-speaks-first protocols,
or client-speaks-first protocols when paired with “0RTT” data. This
comes at the cost of a subtle weakening of the normal handshake
integrity guarantees that TLS provides. Note that the initial
<code>ClientHello</code> is indirectly authenticated because it is included
in the transcript used to derive the keys used to encrypt the data.</p>
<p>This only applies to TLS1.3 connections. TLS1.2 connections cannot
do this optimisation and this setting is ignored for them. It is
also ignored for TLS1.3 connections that even attempt client
authentication.</p>
<p>This defaults to false. This means the first application data
sent by the server comes after receiving and validating the clients
handshake up to the <code>Finished</code> message. This is the safest option.</p>
</div><span id="structfield.send_tls13_tickets" class="structfield section-header"><a href="#structfield.send_tls13_tickets" class="anchor field">§</a><code>send_tls13_tickets: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.usize.html">usize</a></code></span><div class="docblock"><p>How many TLS1.3 tickets to send immediately after a successful
handshake.</p>
<p>Because TLS1.3 tickets are single-use, this allows
a client to perform multiple resumptions.</p>
<p>The default is 4.</p>
<p>If this is 0, no tickets are sent and clients will not be able to
do any resumption.</p>
</div><span id="structfield.time_provider" class="structfield section-header"><a href="#structfield.time_provider" class="anchor field">§</a><code>time_provider: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn TimeProvider&gt;</code></span><div class="docblock"><p>Provides the current system time</p>
</div><span id="structfield.cert_compressors" class="structfield section-header"><a href="#structfield.cert_compressors" class="anchor field">§</a><code>cert_compressors: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html" title="struct alloc::vec::Vec">Vec</a>&lt;&amp;'static dyn CertCompressor&gt;</code></span><div class="docblock"><p>How to compress the servers certificate chain.</p>
<p>If a client supports this extension, and advertises support
for one of the compression algorithms included here, the
server certificate will be compressed according to <a href="https://datatracker.ietf.org/doc/rfc8879/">RFC8779</a>.</p>
<p>This only applies to TLS1.3 connections. It is ignored for
TLS1.2 connections.</p>
</div><span id="structfield.cert_compression_cache" class="structfield section-header"><a href="#structfield.cert_compression_cache" class="anchor field">§</a><code>cert_compression_cache: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;CompressionCache&gt;</code></span><div class="docblock"><p>Caching for compressed certificates.</p>
<p>This is optional: [<code>compress::CompressionCache::Disabled</code>] gives
a cache that does no caching.</p>
</div><span id="structfield.cert_decompressors" class="structfield section-header"><a href="#structfield.cert_decompressors" class="anchor field">§</a><code>cert_decompressors: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html" title="struct alloc::vec::Vec">Vec</a>&lt;&amp;'static dyn CertDecompressor&gt;</code></span><div class="docblock"><p>How to decompress the clientss certificate chain.</p>
<p>If this is non-empty, the <a href="https://datatracker.ietf.org/doc/rfc8879/">RFC8779</a> certificate compression
extension is offered when requesting client authentication,
and any compressed certificates are transparently decompressed
during the handshake.</p>
<p>This only applies to TLS1.3 connections. It is ignored for
TLS1.2 connections.</p>
</div><h2 id="implementations" class="section-header">Implementations<a href="#implementations" class="anchor">§</a></h2><div id="implementations-list"><details class="toggle implementors-toggle" open><summary><section id="impl-ServerConfig" class="impl"><a href="#impl-ServerConfig" class="anchor">§</a><h3 class="code-header">impl <a class="struct" href="struct.ServerConfig.html" title="struct actix_tls::accept::rustls_0_23::reexports::ServerConfig">ServerConfig</a></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.builder" class="method"><h4 class="code-header">pub fn <a href="#method.builder" class="fn">builder</a>() -&gt; ConfigBuilder&lt;<a class="struct" href="struct.ServerConfig.html" title="struct actix_tls::accept::rustls_0_23::reexports::ServerConfig">ServerConfig</a>, WantsVerifier&gt;</h4></section></summary><div class="docblock"><p>Create a builder for a server configuration with
[the process-default <code>CryptoProvider</code>][CryptoProvider#using-the-per-process-default-cryptoprovider]
and safe protocol version defaults.</p>
<p>For more information, see the [<code>ConfigBuilder</code>] documentation.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.builder_with_protocol_versions" class="method"><h4 class="code-header">pub fn <a href="#method.builder_with_protocol_versions" class="fn">builder_with_protocol_versions</a>(
versions: &amp;[&amp;'static SupportedProtocolVersion],
) -&gt; ConfigBuilder&lt;<a class="struct" href="struct.ServerConfig.html" title="struct actix_tls::accept::rustls_0_23::reexports::ServerConfig">ServerConfig</a>, WantsVerifier&gt;</h4></section></summary><div class="docblock"><p>Create a builder for a server configuration with
[the process-default <code>CryptoProvider</code>][CryptoProvider#using-the-per-process-default-cryptoprovider]
and the provided protocol versions.</p>
<p>Panics if</p>
<ul>
<li>the supported versions are not compatible with the provider (eg.
the combination of ciphersuites supported by the provider and supported
versions lead to zero cipher suites being usable),</li>
<li>if a <code>CryptoProvider</code> cannot be resolved using a combination of
the crate features and process default.</li>
</ul>
<p>For more information, see the [<code>ConfigBuilder</code>] documentation.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.builder_with_provider" class="method"><h4 class="code-header">pub fn <a href="#method.builder_with_provider" class="fn">builder_with_provider</a>(
provider: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;CryptoProvider&gt;,
) -&gt; ConfigBuilder&lt;<a class="struct" href="struct.ServerConfig.html" title="struct actix_tls::accept::rustls_0_23::reexports::ServerConfig">ServerConfig</a>, WantsVersions&gt;</h4></section></summary><div class="docblock"><p>Create a builder for a server configuration with a specific [<code>CryptoProvider</code>].</p>
<p>This will use the providers configured ciphersuites. You must additionally choose
which protocol versions to enable, using <code>with_protocol_versions</code> or
<code>with_safe_default_protocol_versions</code> and handling the <code>Result</code> in case a protocol
version is not supported by the providers ciphersuites.</p>
<p>For more information, see the [<code>ConfigBuilder</code>] documentation.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.builder_with_details" class="method"><h4 class="code-header">pub fn <a href="#method.builder_with_details" class="fn">builder_with_details</a>(
provider: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;CryptoProvider&gt;,
time_provider: <a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn TimeProvider&gt;,
) -&gt; ConfigBuilder&lt;<a class="struct" href="struct.ServerConfig.html" title="struct actix_tls::accept::rustls_0_23::reexports::ServerConfig">ServerConfig</a>, WantsVersions&gt;</h4></section></summary><div class="docblock"><p>Create a builder for a server configuration with no default implementation details.</p>
<p>This API must be used by <code>no_std</code> users.</p>
<p>You must provide a specific [<code>TimeProvider</code>].</p>
<p>You must provide a specific [<code>CryptoProvider</code>].</p>
<p>This will use the providers configured ciphersuites. You must additionally choose
which protocol versions to enable, using <code>with_protocol_versions</code> or
<code>with_safe_default_protocol_versions</code> and handling the <code>Result</code> in case a protocol
version is not supported by the providers ciphersuites.</p>
<p>For more information, see the [<code>ConfigBuilder</code>] documentation.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.fips" class="method"><h4 class="code-header">pub fn <a href="#method.fips" class="fn">fips</a>(&amp;self) -&gt; <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.bool.html">bool</a></h4></section></summary><div class="docblock"><p>Return <code>true</code> if connections made with this <code>ServerConfig</code> will
operate in FIPS mode.</p>
<p>This is different from [<code>CryptoProvider::fips()</code>]: [<code>CryptoProvider::fips()</code>]
is concerned only with cryptography, whereas this <em>also</em> covers TLS-level
configuration that NIST recommends.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.crypto_provider" class="method"><h4 class="code-header">pub fn <a href="#method.crypto_provider" class="fn">crypto_provider</a>(&amp;self) -&gt; &amp;<a class="struct" href="https://doc.rust-lang.org/nightly/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;CryptoProvider&gt;</h4></section></summary><div class="docblock"><p>Return the crypto provider used to construct this client configuration.</p>
</div></details></div></details></div><h2 id="trait-implementations" class="section-header">Trait Implementations<a href="#trait-implementations" class="anchor">§</a></h2><div id="trait-implementations-list"><details class="toggle implementors-toggle" open><summary><section id="impl-Clone-for-ServerConfig" class="impl"><a href="#impl-Clone-for-ServerConfig" class="anchor">§</a><h3 class="code-header">impl <a class="trait" href="https://doc.rust-lang.org/nightly/core/clone/trait.Clone.html" title="trait core::clone::Clone">Clone</a> for <a class="struct" href="struct.ServerConfig.html" title="struct actix_tls::accept::rustls_0_23::reexports::ServerConfig">ServerConfig</a></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.clone" class="method trait-impl"><a href="#method.clone" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/core/clone/trait.Clone.html#tymethod.clone" class="fn">clone</a>(&amp;self) -&gt; <a class="struct" href="struct.ServerConfig.html" title="struct actix_tls::accept::rustls_0_23::reexports::ServerConfig">ServerConfig</a></h4></section></summary><div class='docblock'>Returns a copy of the value. <a href="https://doc.rust-lang.org/nightly/core/clone/trait.Clone.html#tymethod.clone">Read more</a></div></details><details class="toggle method-toggle" open><summary><section id="method.clone_from" class="method trait-impl"><span class="rightside"><span class="since" title="Stable since Rust version 1.6.0">1.6.0</span> · <a class="src" href="https://doc.rust-lang.org/nightly/src/core/clone.rs.html#174">source</a></span><a href="#method.clone_from" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/core/clone/trait.Clone.html#method.clone_from" class="fn">clone_from</a>(&amp;mut self, source: &amp;Self)</h4></section></summary><div class='docblock'>Performs copy-assignment from <code>source</code>. <a href="https://doc.rust-lang.org/nightly/core/clone/trait.Clone.html#method.clone_from">Read more</a></div></details></div></details><details class="toggle implementors-toggle" open><summary><section id="impl-Debug-for-ServerConfig" class="impl"><a href="#impl-Debug-for-ServerConfig" class="anchor">§</a><h3 class="code-header">impl <a class="trait" href="https://doc.rust-lang.org/nightly/core/fmt/trait.Debug.html" title="trait core::fmt::Debug">Debug</a> for <a class="struct" href="struct.ServerConfig.html" title="struct actix_tls::accept::rustls_0_23::reexports::ServerConfig">ServerConfig</a></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.fmt" class="method trait-impl"><a href="#method.fmt" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/core/fmt/trait.Debug.html#tymethod.fmt" class="fn">fmt</a>(&amp;self, f: &amp;mut <a class="struct" href="https://doc.rust-lang.org/nightly/core/fmt/struct.Formatter.html" title="struct core::fmt::Formatter">Formatter</a>&lt;'_&gt;) -&gt; <a class="enum" href="https://doc.rust-lang.org/nightly/core/result/enum.Result.html" title="enum core::result::Result">Result</a>&lt;<a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.unit.html">()</a>, <a class="struct" href="https://doc.rust-lang.org/nightly/core/fmt/struct.Error.html" title="struct core::fmt::Error">Error</a>&gt;</h4></section></summary><div class='docblock'>Formats the value using the given formatter. <a href="https://doc.rust-lang.org/nightly/core/fmt/trait.Debug.html#tymethod.fmt">Read more</a></div></details></div></details><section id="impl-ConfigSide-for-ServerConfig" class="impl"><a href="#impl-ConfigSide-for-ServerConfig" class="anchor">§</a><h3 class="code-header">impl ConfigSide for <a class="struct" href="struct.ServerConfig.html" title="struct actix_tls::accept::rustls_0_23::reexports::ServerConfig">ServerConfig</a></h3></section></div><h2 id="synthetic-implementations" class="section-header">Auto Trait Implementations<a
T: 'static + ?<a class="trait" href="https://doc.rust-lang.org/nightly/core/marker/trait.Sized.html" title="trait core::marker::Sized">Sized</a>,</div></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.type_id" class="method trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/any.rs.html#139">source</a><a href="#method.type_id" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/core/any/trait.Any.html#tymethod.type_id" class="fn">type_id</a>(&amp;self) -&gt; <a class="struct" href="https://doc.rust-lang.org/nightly/core/any/struct.TypeId.html" title="struct core::any::TypeId">TypeId</a></h4></section></summary><div class='docblock'>Gets the <code>TypeId</code> of <code>self</code>. <a href="https://doc.rust-lang.org/nightly/core/any/trait.Any.html#tymethod.type_id">Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-Borrow%3CT%3E-for-T" class="impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/borrow.rs.html#209">source</a><a href="#impl-Borrow%3CT%3E-for-T" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; <a class="trait" href="https://doc.rust-lang.org/nightly/core/borrow/trait.Borrow.html" title="trait core::borrow::Borrow">Borrow</a>&lt;T&gt; for T<div class="where">where
T: ?<a class="trait" href="https://doc.rust-lang.org/nightly/core/marker/trait.Sized.html" title="trait core::marker::Sized">Sized</a>,</div></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.borrow" class="method trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/borrow.rs.html#211">source</a><a href="#method.borrow" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/core/borrow/trait.Borrow.html#tymethod.borrow" class="fn">borrow</a>(&amp;self) -&gt; <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.reference.html">&amp;T</a></h4></section></summary><div class='docblock'>Immutably borrows from an owned value. <a href="https://doc.rust-lang.org/nightly/core/borrow/trait.Borrow.html#tymethod.borrow">Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-BorrowMut%3CT%3E-for-T" class="impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/borrow.rs.html#217">source</a><a href="#impl-BorrowMut%3CT%3E-for-T" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; <a class="trait" href="https://doc.rust-lang.org/nightly/core/borrow/trait.BorrowMut.html" title="trait core::borrow::BorrowMut">BorrowMut</a>&lt;T&gt; for T<div class="where">where
T: ?<a class="trait" href="https://doc.rust-lang.org/nightly/core/marker/trait.Sized.html" title="trait core::marker::Sized">Sized</a>,</div></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.borrow_mut" class="method trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/borrow.rs.html#218">source</a><a href="#method.borrow_mut" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/core/borrow/trait.BorrowMut.html#tymethod.borrow_mut" class="fn">borrow_mut</a>(&amp;mut self) -&gt; <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.reference.html">&amp;mut T</a></h4></section></summary><div class='docblock'>Mutably borrows from an owned value. <a href="https://doc.rust-lang.org/nightly/core/borrow/trait.BorrowMut.html#tymethod.borrow_mut">Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-CloneToUninit-for-T" class="impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/clone.rs.html#273">source</a><a href="#impl-CloneToUninit-for-T" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; <a class="trait" href="https://doc.rust-lang.org/nightly/core/clone/trait.CloneToUninit.html" title="trait core::clone::CloneToUninit">CloneToUninit</a> for T<div class="where">where
T: <a class="trait" href="https://doc.rust-lang.org/nightly/core/clone/trait.Clone.html" title="trait core::clone::Clone">Clone</a>,</div></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.clone_to_uninit" class="method trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/clone.rs.html#275">source</a><a href="#method.clone_to_uninit" class="anchor">§</a><h4 class="code-header">unsafe fn <a href="https://doc.rust-lang.org/nightly/core/clone/trait.CloneToUninit.html#tymethod.clone_to_uninit" class="fn">clone_to_uninit</a>(&amp;self, dst: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.pointer.html">*mut T</a>)</h4></section></summary><span class="item-info"><div class="stab unstable"><span class="emoji">🔬</span><span>This is a nightly-only experimental API. (<code>clone_to_uninit</code>)</span></div></span><div class='docblock'>Performs copy-assignment from <code>self</code> to <code>dst</code>. <a href="https://doc.rust-lang.org/nightly/core/clone/trait.CloneToUninit.html#tymethod.clone_to_uninit">Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-From%3CT%3E-for-T" class="impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/convert/mod.rs.html#765">source</a><a href="#impl-From%3CT%3E-for-T" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; <a class="trait" href="https://doc.rust-lang.org/nightly/core/convert/trait.From.html" title="trait core::convert::From">From</a>&lt;T&gt; for T</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.from" class="method trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/convert/mod.rs.html#768">source</a><a href="#method.from" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/core/convert/trait.From.html#tymethod.from" class="fn">from</a>(t: T) -&gt; T</h4></section></summary><div class="docblock"><p>Returns the argument unchanged.</p>
</div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-Instrument-for-T" class="impl"><a href="#impl-Instrument-for-T" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; Instrument for T</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.instrument" class="method trait-impl"><a href="#method.instrument" class="anchor">§</a><h4 class="code-header">fn <a class="fn">instrument</a>(self, span: Span) -&gt; Instrumented&lt;Self&gt;</h4></section></summary><div class='docblock'>Instruments this type with the provided [<code>Span</code>], returning an
<code>Instrumented</code> wrapper. <a>Read more</a></div></details><details class="toggle method-toggle" open><summary><section id="method.in_current_span" class="method trait-impl"><a href="#method.in_current_span" class="anchor">§</a><h4 class="code-header">fn <a class="fn">in_current_span</a>(self) -&gt; Instrumented&lt;Self&gt;</h4></section></summary><div class='docblock'>Instruments this type with the <a href="super::Span::current()">current</a> <a href="crate::Span"><code>Span</code></a>, returning an
<code>Instrumented</code> wrapper. <a>Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-Into%3CU%3E-for-T" class="impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/convert/mod.rs.html#748-750">source</a><a href="#impl-Into%3CU%3E-for-T" class="anchor">§</a><h3 class="code-header">impl&lt;T, U&gt; <a class="trait" href="https://doc.rust-lang.org/nightly/core/convert/trait.Into.html" title="trait core::convert::Into">Into</a>&lt;U&gt; for T<div class="where">where
U: <a class="trait" href="https://doc.rust-lang.org/nightly/core/convert/trait.From.html" title="trait core::convert::From">From</a>&lt;T&gt;,</div></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.into" class="method trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/convert/mod.rs.html#758">source</a><a href="#method.into" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/core/convert/trait.Into.html#tymethod.into" class="fn">into</a>(self) -&gt; U</h4></section></summary><div class="docblock"><p>Calls <code>U::from(self)</code>.</p>
<p>That is, this conversion is whatever the implementation of
<code><a href="https://doc.rust-lang.org/nightly/core/convert/trait.From.html" title="trait core::convert::From">From</a>&lt;T&gt; for U</code> chooses to do.</p>
</div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-ToOwned-for-T" class="impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/alloc/borrow.rs.html#82-84">source</a><a href="#impl-ToOwned-for-T" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; <a class="trait" href="https://doc.rust-lang.org/nightly/alloc/borrow/trait.ToOwned.html" title="trait alloc::borrow::ToOwned">ToOwned</a> for T<div class="where">where
T: <a class="trait" href="https://doc.rust-lang.org/nightly/core/clone/trait.Clone.html" title="trait core::clone::Clone">Clone</a>,</div></h3></section></summary><div class="impl-items"><details class="toggle" open><summary><section id="associatedtype.Owned" class="associatedtype trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/alloc/borrow.rs.html#86">source</a><a href="#associatedtype.Owned" class="anchor">§</a><h4 class="code-header">type <a href="https://doc.rust-lang.org/nightly/alloc/borrow/trait.ToOwned.html#associatedtype.Owned" class="associatedtype">Owned</a> = T</h4></section></summary><div class='docblock'>The resulting type after obtaining ownership.</div></details><details class="toggle method-toggle" open><summary><section id="method.to_owned" class="method trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/alloc/borrow.rs.html#87">source</a><a href="#method.to_owned" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/alloc/borrow/trait.ToOwned.html#tymethod.to_owned" class="fn">to_owned</a>(&amp;self) -&gt; T</h4></section></summary><div class='docblock'>Creates owned data from borrowed data, usually by cloning. <a href="https://doc.rust-lang.org/nightly/alloc/borrow/trait.ToOwned.html#tymethod.to_owned">Read more</a></div></details><details class="toggle method-toggle" open><summary><section id="method.clone_into" class="method trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/alloc/borrow.rs.html#91">source</a><a href="#method.clone_into" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/alloc/borrow/trait.ToOwned.html#method.clone_into" class="fn">clone_into</a>(&amp;self, target: <a class="primitive" href="https://doc.rust-lang.org/nightly/std/primitive.reference.html">&amp;mut T</a>)</h4></section></summary><div class='docblock'>Uses borrowed data to replace owned data, usually by cloning. <a href="https://doc.rust-lang.org/nightly/alloc/borrow/trait.ToOwned.html#method.clone_into">Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-TryFrom%3CU%3E-for-T" class="impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/convert/mod.rs.html#805-807">source</a><a href="#impl-TryFrom%3CU%3E-for-T" class="anchor">§</a><h3 class="code-header">impl&lt;T, U&gt; <a class="trait" href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html" title="trait core::convert::TryFrom">TryFrom</a>&lt;U&gt; for T<div class="where">where
U: <a class="trait" href="https://doc.rust-lang.org/nightly/core/convert/trait.Into.html" title="trait core::convert::Into">Into</a>&lt;T&gt;,</div></h3></section></summary><div class="impl-items"><details class="toggle" open><summary><section id="associatedtype.Error-1" class="associatedtype trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/convert/mod.rs.html#809">source</a><a href="#associatedtype.Error-1" class="anchor">§</a><h4 class="code-header">type <a href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html#associatedtype.Error" class="associatedtype">Error</a> = <a class="enum" href="https://doc.rust-lang.org/nightly/core/convert/enum.Infallible.html" title="enum core::convert::Infallible">Infallible</a></h4></section></summary><div class='docblock'>The type returned in the event of a conversion error.</div></details><details class="toggle method-toggle" open><summary><section id="method.try_from" class="method trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/convert/mod.rs.html#812">source</a><a href="#method.try_from" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html#tymethod.try_from" class="fn">try_from</a>(value: U) -&gt; <a class="enum" href="https://doc.rust-lang.org/nightly/core/result/enum.Result.html" title="enum core::result::Result">Result</a>&lt;T, &lt;T as <a class="trait" href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html" title="trait core::convert::TryFrom">TryFrom</a>&lt;U&gt;&gt;::<a class="associatedtype" href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html#associatedtype.Error" title="type core::convert::TryFrom::Error">Error</a>&gt;</h4></section></summary><div class='docblock'>Performs the conversion.</div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-TryInto%3CU%3E-for-T" class="impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/convert/mod.rs.html#790-792">source</a><a href="#impl-TryInto%3CU%3E-for-T" class="anchor">§</a><h3 class="code-header">impl&lt;T, U&gt; <a class="trait" href="https://doc.rust-lang.org/nightly/core/convert/trait.TryInto.html" title="trait core::convert::TryInto">TryInto</a>&lt;U&gt; for T<div class="where">where
U: <a class="trait" href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html" title="trait core::convert::TryFrom">TryFrom</a>&lt;T&gt;,</div></h3></section></summary><div class="impl-items"><details class="toggle" open><summary><section id="associatedtype.Error" class="associatedtype trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/convert/mod.rs.html#794">source</a><a href="#associatedtype.Error" class="anchor">§</a><h4 class="code-header">type <a href="https://doc.rust-lang.org/nightly/core/convert/trait.TryInto.html#associatedtype.Error" class="associatedtype">Error</a> = &lt;U as <a class="trait" href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html" title="trait core::convert::TryFrom">TryFrom</a>&lt;T&gt;&gt;::<a class="associatedtype" href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html#associatedtype.Error" title="type core::convert::TryFrom::Error">Error</a></h4></section></summary><div class='docblock'>The type returned in the event of a conversion error.</div></details><details class="toggle method-toggle" open><summary><section id="method.try_into" class="method trait-impl"><a class="src rightside" href="https://doc.rust-lang.org/nightly/src/core/convert/mod.rs.html#797">source</a><a href="#method.try_into" class="anchor">§</a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/nightly/core/convert/trait.TryInto.html#tymethod.try_into" class="fn">try_into</a>(self) -&gt; <a class="enum" href="https://doc.rust-lang.org/nightly/core/result/enum.Result.html" title="enum core::result::Result">Result</a>&lt;U, &lt;U as <a class="trait" href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html" title="trait core::convert::TryFrom">TryFrom</a>&lt;T&gt;&gt;::<a class="associatedtype" href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html#associatedtype.Error" title="type core::convert::TryFrom::Error">Error</a>&gt;</h4></section></summary><div class='docblock'>Performs the conversion.</div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-WithSubscriber-for-T" class="impl"><a href="#impl-WithSubscriber-for-T" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; WithSubscriber for T</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.with_subscriber" class="method trait-impl"><a href="#method.with_subscriber" class="anchor">§</a><h4 class="code-header">fn <a class="fn">with_subscriber</a>&lt;S&gt;(self, subscriber: S) -&gt; WithDispatch&lt;Self&gt;<div class="where">where
S: <a class="trait" href="https://doc.rust-lang.org/nightly/core/convert/trait.Into.html" title="trait core::convert::Into">Into</a>&lt;Dispatch&gt;,</div></h4></section></summary><div class='docblock'>Attaches the provided <a href="super::Subscriber"><code>Subscriber</code></a> to this type, returning a
[<code>WithDispatch</code>] wrapper. <a>Read more</a></div></details><details class="toggle method-toggle" open><summary><section id="method.with_current_subscriber" class="method trait-impl"><a href="#method.with_current_subscriber" class="anchor">§</a><h4 class="code-header">fn <a class="fn">with_current_subscriber</a>(self) -&gt; WithDispatch&lt;Self&gt;</h4></section></summary><div class='docblock'>Attaches the current <a href="crate::dispatcher#setting-the-default-subscriber">default</a> <a href="super::Subscriber"><code>Subscriber</code></a> to this type, returning a
[<code>WithDispatch</code>] wrapper. <a>Read more</a></div></details></div></details></div></section></div></main></body></html>