pub struct BoringSSLConfig { /* private fields */ }Available on crate feature
tls-boringssl only.Expand description
BoringSSL configuration.
Implementations§
Source§impl BoringSSLConfig
impl BoringSSLConfig
Sourcepub fn from_pem_file<A: AsRef<Path>, B: AsRef<Path>>(
cert: A,
key: B,
) -> Result<Self, BoringSSLError>
pub fn from_pem_file<A: AsRef<Path>, B: AsRef<Path>>( cert: A, key: B, ) -> Result<Self, BoringSSLError>
This helper will established a TLS server based on strong cipher suites from a PEM formatted certificate and key.
Examples found in repository?
examples/boringssl_server.rs (lines 13-16)
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
async fn main() {
let app = Router::new().route("/", get(|| async { "Hello, world!" }));
let config = BoringSSLConfig::from_pem_file(
"examples/self-signed-certs/cert.pem",
"examples/self-signed-certs/key.pem",
)
.unwrap();
let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
println!("listening on {}", addr);
axum_server2::bind_boringssl(addr, config)
.serve(app.into_make_service())
.await
.unwrap();
}Sourcepub fn from_pem_chain_file<A: AsRef<Path>, B: AsRef<Path>>(
chain: A,
key: B,
) -> Result<Self, BoringSSLError>
pub fn from_pem_chain_file<A: AsRef<Path>, B: AsRef<Path>>( chain: A, key: B, ) -> Result<Self, BoringSSLError>
This helper will established a TLS server based on strong cipher suites from a PEM formatted certificate chain and key.
Trait Implementations§
Source§impl Clone for BoringSSLConfig
impl Clone for BoringSSLConfig
Source§fn clone(&self) -> BoringSSLConfig
fn clone(&self) -> BoringSSLConfig
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 BoringSSLConfig
impl Debug for BoringSSLConfig
Source§impl TryFrom<SslAcceptorBuilder> for BoringSSLConfig
impl TryFrom<SslAcceptorBuilder> for BoringSSLConfig
Source§fn try_from(tls_builder: SslAcceptorBuilder) -> Result<Self, Self::Error>
fn try_from(tls_builder: SslAcceptorBuilder) -> Result<Self, Self::Error>
Build the BoringSSLConfig from an SslAcceptorBuilder. This allows precise
control over the settings that will be used by BoringSSL in this server.
§Example
use axum_server2::tls_boringssl::BoringSSLConfig;
use boring::ssl::{SslAcceptor, SslMethod};
use std::convert::TryFrom;
#[tokio::main]
async fn main() {
let mut tls_builder = SslAcceptor::mozilla_intermediate_v5(SslMethod::tls())
.unwrap();
// Set configurations like set_certificate_chain_file or
// set_private_key_file.
// let tls_builder.set_ ... ;
let _config = BoringSSLConfig::try_from(tls_builder);
}Auto Trait Implementations§
impl Freeze for BoringSSLConfig
impl RefUnwindSafe for BoringSSLConfig
impl Send for BoringSSLConfig
impl Sync for BoringSSLConfig
impl Unpin for BoringSSLConfig
impl UnwindSafe for BoringSSLConfig
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,
Source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit)