diff options
author | Quentin Dufour <quentin@deuxfleurs.fr> | 2022-06-02 17:12:58 +0200 |
---|---|---|
committer | Quentin Dufour <quentin@deuxfleurs.fr> | 2022-06-02 17:12:58 +0200 |
commit | 3370760891d05ded9ec5fabac634f5c08ef6ba46 (patch) | |
tree | 890e88891936f5e9429397d815a7866cb88f3a60 | |
parent | 81e647e8818590a5589803cd810ff3018698e786 (diff) | |
download | aerogramme-3370760891d05ded9ec5fabac634f5c08ef6ba46.tar.gz aerogramme-3370760891d05ded9ec5fabac634f5c08ef6ba46.zip |
Working services
-rw-r--r-- | src/server.rs | 22 |
1 files changed, 19 insertions, 3 deletions
diff --git a/src/server.rs b/src/server.rs index e9b05d8..81ffcd5 100644 --- a/src/server.rs +++ b/src/server.rs @@ -46,6 +46,22 @@ impl Service<Request> for Echo { } } +struct Charlie; +impl<'a> Service<&'a AddrStream> for Charlie { + type Response = Echo; + type Error = anyhow::Error; + type Future = Pin<Box<dyn futures::Future<Output = Result<Self::Response>> + Send>>; + + fn poll_ready(&mut self, cx: &mut Context<'_>) -> Poll<Result<(), Self::Error>> { + Poll::Ready(Ok(())) + } + + fn call(&mut self, addr: &'a AddrStream) -> Self::Future { + println!("{}, {}", addr.remote_addr, addr.local_addr); + let fut = futures::future::ok(Echo); + Box::pin(fut) + } +} impl Server { pub fn new(config: Config) -> Result<Arc<Self>> { @@ -73,18 +89,18 @@ impl Server { let incoming = AddrIncoming::new("127.0.0.1:4567").await?; - let make_service = tower::service_fn(|addr: &AddrStream| { + /*let make_service = tower::service_fn(|addr: &AddrStream| { tracing::debug!(remote_addr = %addr.remote_addr, local_addr = %addr.local_addr, "accept"); //let service = tower::ServiceBuilder::new().service_fn(handle_req); //let service = tower::service_fn(handle_req); let service = Echo; futures::future::ok::<_, std::convert::Infallible>(service) //service - }); + });*/ //println!("{:?}", make_service); - let server = ImapServer::new(incoming).serve(make_service); + let server = ImapServer::new(incoming).serve(Charlie); let _ = server.await?; /*let creds = self.login_provider.login("quentin", "poupou").await?; |