From 852ea1480a1a2d22881c934fd6533b6701527436 Mon Sep 17 00:00:00 2001 From: hatoo Date: Wed, 20 Dec 2023 18:13:44 +0900 Subject: [PATCH] Make Cert generic --- src/lib.rs | 16 +++++++++------- tests/test.rs | 2 +- 2 files changed, 10 insertions(+), 8 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 216a81e..13800b1 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -14,7 +14,7 @@ use hyper::{ Method, Request, Response, StatusCode, Uri, }; use hyper_util::rt::TokioIo; -use std::{future::Future, sync::Arc}; +use std::{future::Future, ops::Deref, process::Output, sync::Arc}; use tls::server_config; use tokio::{ io::{AsyncReadExt, AsyncWriteExt}, @@ -29,18 +29,18 @@ pub use tokio_native_tls; mod tls; #[derive(Clone)] /// The main struct to run proxy server -pub struct MitmProxy { +pub struct MitmProxy { /// Root certificate to sign fake certificates. You may need to trust this certificate on client application to use HTTPS. /// /// If None, proxy will just tunnel HTTPS traffic and will not observe HTTPS traffic. - pub root_cert: Option>, + pub root_cert: Option, /// TLS connector to connect from proxy to server. pub tls_connector: tokio_native_tls::native_tls::TlsConnector, } -impl MitmProxy { +impl MitmProxy { pub fn new( - root_cert: Option>, + root_cert: Option, tls_connector: tokio_native_tls::native_tls::TlsConnector, ) -> Self { Self { @@ -77,7 +77,8 @@ pub struct Communication { pub upgrade: futures::channel::oneshot::Receiver, } -impl MitmProxy { +/// C is typically Arc or &'static Certificate +impl + Clone + Send + Sync + 'static> MitmProxy { /// Bind proxy server to address. /// You can observe communications between client and server by receiving stream. /// To run proxy server, you need to run returned future. This API design give you an ability to cancel proxy server when you want. @@ -169,7 +170,8 @@ impl MitmProxy { }; if let Some(root_cert) = proxy.root_cert.as_ref() { - let Ok(server_config) = server_config(host.to_string(), root_cert) else { + let Ok(server_config) = server_config(host.to_string(), root_cert.deref()) + else { tracing::error!("Failed to create server config for {}", host); return; }; diff --git a/tests/test.rs b/tests/test.rs index 5d9dc20..a790916 100644 --- a/tests/test.rs +++ b/tests/test.rs @@ -105,7 +105,7 @@ where tokio::spawn(server); - let proxy = http_mitm_proxy::MitmProxy::new( + let proxy = http_mitm_proxy::MitmProxy::<&'static rcgen::Certificate>::new( None, tokio_native_tls::native_tls::TlsConnector::new().unwrap(), );