Struct TlsMitmRelay
pub struct TlsMitmRelay<Issuer> { /* private fields */ }Expand description
A utility that can be used by MITM services such as transparent proxies, in order to relay (and MITM a TLS connection between a client and server, as part of a deep protocol inspection protocol (DPI) flow.
Implementations§
§impl<Issuer> TlsMitmRelay<Issuer>
impl<Issuer> TlsMitmRelay<Issuer>
pub fn new(issuer: Issuer) -> TlsMitmRelay<Issuer>
pub fn new(issuer: Issuer) -> TlsMitmRelay<Issuer>
Create a new TlsMitmRelay.
pub fn with_grease_enabled(self, enabled: bool) -> TlsMitmRelay<Issuer>
pub fn with_grease_enabled(self, enabled: bool) -> TlsMitmRelay<Issuer>
Set whether GREASE should be enabled for the ingress-side TLS acceptor.
By default is is enabled (true).
pub fn set_grease_enabled(&mut self, enabled: bool) -> &mut TlsMitmRelay<Issuer>
pub fn set_grease_enabled(&mut self, enabled: bool) -> &mut TlsMitmRelay<Issuer>
Set whether GREASE should be enabled for the ingress-side TLS acceptor.
By default is is enabled (true).
pub fn with_keylog_intent(self, intent: KeyLogIntent) -> TlsMitmRelay<Issuer>
pub fn with_keylog_intent(self, intent: KeyLogIntent) -> TlsMitmRelay<Issuer>
Set the [keylog_intent].
By default KeyLogIntent::Environment is used.
pub fn set_keylog_intent(
&mut self,
intent: KeyLogIntent,
) -> &mut TlsMitmRelay<Issuer>
pub fn set_keylog_intent( &mut self, intent: KeyLogIntent, ) -> &mut TlsMitmRelay<Issuer>
Set the [keylog_intent].
By default KeyLogIntent::Environment is used.
§impl<Issuer> TlsMitmRelay<CachedBoringMitmCertIssuer<Issuer>>
impl<Issuer> TlsMitmRelay<CachedBoringMitmCertIssuer<Issuer>>
pub fn new_with_cached_issuer(
issuer: Issuer,
) -> TlsMitmRelay<CachedBoringMitmCertIssuer<Issuer>>
pub fn new_with_cached_issuer( issuer: Issuer, ) -> TlsMitmRelay<CachedBoringMitmCertIssuer<Issuer>>
Create a new TlsMitmRelay,
with a cache layer on top top of the provided issuer
toprovide reuse functionality of previously issued certs.
pub fn new_with_cached_issuer_and_config(
issuer: Issuer,
cfg: BoringMitmCertIssuerCacheConfig,
) -> TlsMitmRelay<CachedBoringMitmCertIssuer<Issuer>>
pub fn new_with_cached_issuer_and_config( issuer: Issuer, cfg: BoringMitmCertIssuerCacheConfig, ) -> TlsMitmRelay<CachedBoringMitmCertIssuer<Issuer>>
Create a new TlsMitmRelay,
with a cache layer (created by given config)
on top of the provided issuer to provide reuse functionality of previously issued certs.
§impl TlsMitmRelay<InMemoryBoringMitmCertIssuer>
impl TlsMitmRelay<InMemoryBoringMitmCertIssuer>
pub fn try_new_with_self_signed_issuer(
data: &SelfSignedData,
) -> Result<TlsMitmRelay<InMemoryBoringMitmCertIssuer>, Box<dyn Error + Send + Sync>>
pub fn try_new_with_self_signed_issuer( data: &SelfSignedData, ) -> Result<TlsMitmRelay<InMemoryBoringMitmCertIssuer>, Box<dyn Error + Send + Sync>>
Create a new TlsMitmRelay with self-signed CA using the given data.
pub fn new_in_memory(
crt: X509,
key: PKey<Private>,
) -> TlsMitmRelay<InMemoryBoringMitmCertIssuer>
pub fn new_in_memory( crt: X509, key: PKey<Private>, ) -> TlsMitmRelay<InMemoryBoringMitmCertIssuer>
Create a new TlsMitmRelay with the provided CA pair.
§impl TlsMitmRelay<CachedBoringMitmCertIssuer<InMemoryBoringMitmCertIssuer>>
impl TlsMitmRelay<CachedBoringMitmCertIssuer<InMemoryBoringMitmCertIssuer>>
pub fn try_new_with_cached_self_signed_issuer(
data: &SelfSignedData,
) -> Result<TlsMitmRelay<CachedBoringMitmCertIssuer<InMemoryBoringMitmCertIssuer>>, Box<dyn Error + Send + Sync>>
pub fn try_new_with_cached_self_signed_issuer( data: &SelfSignedData, ) -> Result<TlsMitmRelay<CachedBoringMitmCertIssuer<InMemoryBoringMitmCertIssuer>>, Box<dyn Error + Send + Sync>>
Create a new TlsMitmRelay with self-signed CA using the given data,
with a cache layer on top to provide reuse functionality of previously issued certs.
pub fn try_new_with_cached_self_signed_issuer_and_config(
data: &SelfSignedData,
cfg: BoringMitmCertIssuerCacheConfig,
) -> Result<TlsMitmRelay<CachedBoringMitmCertIssuer<InMemoryBoringMitmCertIssuer>>, Box<dyn Error + Send + Sync>>
pub fn try_new_with_cached_self_signed_issuer_and_config( data: &SelfSignedData, cfg: BoringMitmCertIssuerCacheConfig, ) -> Result<TlsMitmRelay<CachedBoringMitmCertIssuer<InMemoryBoringMitmCertIssuer>>, Box<dyn Error + Send + Sync>>
Create a new TlsMitmRelay with self-signed CA using the given data,
with a cache layer (created by given config)
on top to provide reuse functionality of previously issued certs.
pub fn new_cached_in_memory(
crt: X509,
key: PKey<Private>,
) -> TlsMitmRelay<CachedBoringMitmCertIssuer<InMemoryBoringMitmCertIssuer>>
pub fn new_cached_in_memory( crt: X509, key: PKey<Private>, ) -> TlsMitmRelay<CachedBoringMitmCertIssuer<InMemoryBoringMitmCertIssuer>>
Create a new TlsMitmRelay with the provided CA pair,
with a cache layer on top to provide reuse functionality of previously issued certs.
pub fn new_cached_in_memory_with_config(
crt: X509,
key: PKey<Private>,
cfg: BoringMitmCertIssuerCacheConfig,
) -> TlsMitmRelay<CachedBoringMitmCertIssuer<InMemoryBoringMitmCertIssuer>>
pub fn new_cached_in_memory_with_config( crt: X509, key: PKey<Private>, cfg: BoringMitmCertIssuerCacheConfig, ) -> TlsMitmRelay<CachedBoringMitmCertIssuer<InMemoryBoringMitmCertIssuer>>
Create a new TlsMitmRelay with the provided CA pair,
with a cache layer (created by given config)
on top to provide reuse functionality of previously issued certs.
§impl<Issuer> TlsMitmRelay<Issuer>where
Issuer: BoringMitmCertIssuer,
<Issuer as BoringMitmCertIssuer>::Error: Into<Box<dyn Error + Send + Sync>>,
impl<Issuer> TlsMitmRelay<Issuer>where
Issuer: BoringMitmCertIssuer,
<Issuer as BoringMitmCertIssuer>::Error: Into<Box<dyn Error + Send + Sync>>,
pub async fn handshake<Ingress, Egress>(
&self,
__arg1: BridgeIo<Ingress, Egress>,
connector_data: Option<TlsConnectorData>,
) -> Result<BridgeIo<TlsStream<Ingress>, TlsStream<Egress>>, TlsMitmRelayError>
pub async fn handshake<Ingress, Egress>( &self, __arg1: BridgeIo<Ingress, Egress>, connector_data: Option<TlsConnectorData>, ) -> Result<BridgeIo<TlsStream<Ingress>, TlsStream<Egress>>, TlsMitmRelayError>
Establish and MITM an handshake between the client (ingress) and server (egress).
Trait Implementations§
§impl<Issuer> Clone for TlsMitmRelay<Issuer>where
Issuer: Clone,
impl<Issuer> Clone for TlsMitmRelay<Issuer>where
Issuer: Clone,
§fn clone(&self) -> TlsMitmRelay<Issuer>
fn clone(&self) -> TlsMitmRelay<Issuer>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more§impl<Issuer> Debug for TlsMitmRelay<Issuer>where
Issuer: Debug,
impl<Issuer> Debug for TlsMitmRelay<Issuer>where
Issuer: Debug,
§impl<S, Issuer> Layer<S> for TlsMitmRelay<Issuer>where
Issuer: Clone,
impl<S, Issuer> Layer<S> for TlsMitmRelay<Issuer>where
Issuer: Clone,
§type Service = TlsMitmRelayService<Issuer, S>
type Service = TlsMitmRelayService<Issuer, S>
§fn layer(&self, inner: S) -> <TlsMitmRelay<Issuer> as Layer<S>>::Service
fn layer(&self, inner: S) -> <TlsMitmRelay<Issuer> as Layer<S>>::Service
§fn into_layer(self, inner: S) -> <TlsMitmRelay<Issuer> as Layer<S>>::Service
fn into_layer(self, inner: S) -> <TlsMitmRelay<Issuer> as Layer<S>>::Service
layer but consuming self after the service was created. Read moreAuto Trait Implementations§
impl<Issuer> Freeze for TlsMitmRelay<Issuer>where
Issuer: Freeze,
impl<Issuer> RefUnwindSafe for TlsMitmRelay<Issuer>where
Issuer: RefUnwindSafe,
impl<Issuer> Send for TlsMitmRelay<Issuer>where
Issuer: Send,
impl<Issuer> Sync for TlsMitmRelay<Issuer>where
Issuer: Sync,
impl<Issuer> Unpin for TlsMitmRelay<Issuer>where
Issuer: Unpin,
impl<Issuer> UnsafeUnpin for TlsMitmRelay<Issuer>where
Issuer: UnsafeUnpin,
impl<Issuer> UnwindSafe for TlsMitmRelay<Issuer>where
Issuer: UnwindSafe,
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self> ⓘ
fn with_context(self, otel_cx: Context) -> WithContext<Self> ⓘ
§fn with_current_context(self) -> WithContext<Self> ⓘ
fn with_current_context(self) -> WithContext<Self> ⓘ
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a rama_grpc::Request§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§fn and<P, B, E>(self, other: P) -> And<T, P>
fn and<P, B, E>(self, other: P) -> And<T, P>
Policy that returns Action::Follow only if self and other return
Action::Follow. Read more