Compare commits

..

No commits in common. "c099817e9a83ccb26e5b6b6c25434b0783e9488e" and "1910e1d51a328d45ccfe8f0982a9e14909e5bea8" have entirely different histories.

4 changed files with 2 additions and 40 deletions

1
.gitignore vendored
View file

@ -21,4 +21,3 @@ target/
# Cargo root folder
/.cargo
.idea

View file

@ -1,37 +0,0 @@
use std::error::Error;
use std::net::SocketAddr;
use std::sync::Arc;
use quinn::{ClientConfig, Endpoint};
use rustls::pki_types::CertificateDer;
/// Builds default quinn client config and trusts given certificates.
///
/// ## Args
///
/// - server_certs: a list of trusted certificates in DER format.
fn configure_client(
server_certs: &[&[u8]],
) -> Result<ClientConfig, Box<dyn Error + Send + Sync + 'static>> {
let mut certs = rustls::RootCertStore::empty();
for cert in server_certs {
certs.add(CertificateDer::from(*cert))?;
}
Ok(ClientConfig::with_root_certificates(Arc::new(certs))?)
}
/// Constructs a QUIC endpoint configured for use a client only.
///
/// ## Args
///
/// - server_certs: list of trusted certificates.
#[allow(unused)]
pub fn make_client_endpoint(
bind_addr: SocketAddr,
server_certs: &[&[u8]],
) -> Result<Endpoint, Box<dyn Error + Send + Sync + 'static>> {
let client_cfg = configure_client(server_certs)?;
let mut endpoint = Endpoint::client(bind_addr)?;
endpoint.set_default_client_config(client_cfg);
Ok(endpoint)
}

View file

@ -1,2 +1 @@
mod server;
mod client;

View file

@ -2,6 +2,7 @@ use std::error::Error;
use std::net::SocketAddr;
use std::sync::Arc;
use quinn::{Endpoint, ServerConfig};
use rcgen::Certificate;
use rustls::pki_types::{CertificateDer, PrivatePkcs8KeyDer};
use rustls::pki_types::pem::PemObject;