pub trait Acceptor<Input>: 'static + Clone + Send + Syncwhere
Input: 'static + AsyncRead + AsyncWrite + Send + Sync + Unpin,{
type Output: 'static + AsyncRead + AsyncWrite + Send + Sync + Unpin;
type Error: Debug + Send + Sync;
fn accept<'life0, 'async_trait>(
&'life0 self,
input: Input
) -> Pin<Box<dyn Future<Output = Result<Self::Output, Self::Error>> + Send + 'async_trait, Global>>
where
'life0: 'async_trait,
Self: 'async_trait;
}
Expand description
This trait provides the common interface for server-side tls acceptors, abstracting over various implementations
The only implementation provided by this crate is ()
, which is
a noop acceptor, and passes through the Input
type.
Implementing this trait looks like:
ⓘ
use trillium_tls_common::{AsyncRead, AsyncWrite, async_trait};
#[async_trait]
impl<Input> Acceptor<Input> for my_tls_impl::Acceptor
where
Input: AsyncRead + AsyncWrite + Send + Sync + Unpin + 'static,
{
type Output = my_tls_impl::TlsStream<Input>;
type Error = my_tls_impl::Error;
async fn accept(&self, input: Input) -> Result<Self::Output, Self::Error> {
self.accept(input).await
}
}
Required Associated Types
type Output: 'static + AsyncRead + AsyncWrite + Send + Sync + Unpin
type Output: 'static + AsyncRead + AsyncWrite + Send + Sync + Unpin
The stream type. For example, TlsStream
type Error: Debug + Send + Sync
type Error: Debug + Send + Sync
An error type that Acceptor::accept
may return
Required Methods
fn accept<'life0, 'async_trait>(
&'life0 self,
input: Input
) -> Pin<Box<dyn Future<Output = Result<Self::Output, Self::Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
Self: 'async_trait,
fn accept<'life0, 'async_trait>(
&'life0 self,
input: Input
) -> Pin<Box<dyn Future<Output = Result<Self::Output, Self::Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
Self: 'async_trait,
Transform an Input (AsyncRead + AsyncWrite + Send + Sync + Unpin + 'static
) into Self::Output
Async trait signature:
ⓘ
async fn accept(&self, input: Input) -> Result<Self::Output, Self::Error>;