rok 0.1.2

A stupid simple http web server framework base on hyper.
Documentation
use std::fs::File;
use std::io::{BufReader, Read};
use std::path::Path;
use std::sync::Arc;

use tokio_rustls::rustls::internal::pemfile::{certs, pkcs8_private_keys, rsa_private_keys};
use tokio_rustls::rustls::{NoClientAuth, ServerConfig};
use tokio_rustls::TlsAcceptor;

use crate::errors::errors::Error;

pub fn new_tls_acceptor(
    cert_path: impl AsRef<Path>,
    key_path: impl AsRef<Path>,
) -> Result<TlsAcceptor, Error> {
    let mut config = ServerConfig::new(NoClientAuth::new());
    let certs = certs(&mut BufReader::new(
        File::open(cert_path.as_ref())
            .map_err(|e| crate::errors::errors::error_message!("open cert file failed, err:{:?}", e))?,
    ))
        .map_err(|_| crate::errors::errors::error_message!("invalid cert"))?;

    let mut key_vec = Vec::new();
    File::open(key_path.as_ref())?.read_to_end(&mut key_vec)?;

    let mut reader = BufReader::new(key_vec.as_slice());

    let keys = match pkcs8_private_keys(&mut reader) {
        Ok(pkcs8) => pkcs8,
        Err(_e) => {
            let mut reader = BufReader::new(key_vec.as_slice());
            rsa_private_keys(&mut reader).map_err(|_| crate::errors::errors::error_message!("invalid key"))?
        }
    };

    let key = keys
        .first()
        .ok_or_else(|| crate::errors::errors::error_message!("invalid key, not data"))?;

    config
        .set_single_cert(certs, key.clone())
        .map_err(|e| crate::errors::errors::error_message!("set tls cert failed, err: {:?}", e))?;

    Ok(TlsAcceptor::from(Arc::new(config)))
}