From b82df13082869dc4d455e15c2955e20de0b55675 Mon Sep 17 00:00:00 2001 From: Quentin Dufour Date: Tue, 7 Jun 2022 12:38:59 +0200 Subject: Refactor --- src/connection.rs | 41 ----------------------------------------- 1 file changed, 41 deletions(-) delete mode 100644 src/connection.rs (limited to 'src/connection.rs') diff --git a/src/connection.rs b/src/connection.rs deleted file mode 100644 index 335caaa..0000000 --- a/src/connection.rs +++ /dev/null @@ -1,41 +0,0 @@ -use std::sync::Arc; -use std::task::{Context, Poll}; - -use boitalettres::errors::Error as BalError; -use boitalettres::proto::{Request, Response}; -use futures::future::BoxFuture; -use imap_codec::types::command::CommandBody; -use tower::Service; - -use crate::command; -use crate::mailstore::Mailstore; - -pub struct Connection { - pub mailstore: Arc, -} -impl Connection { - pub fn new(mailstore: Arc) -> Self { - Self { mailstore } - } -} -impl Service for Connection { - type Response = Response; - type Error = BalError; - type Future = BoxFuture<'static, Result>; - - fn poll_ready(&mut self, cx: &mut Context<'_>) -> Poll> { - Poll::Ready(Ok(())) - } - - fn call(&mut self, req: Request) -> Self::Future { - tracing::debug!("Got request: {:#?}", req); - let cmd = command::Command::new(self.mailstore.clone()); - Box::pin(async move { - match req.body { - CommandBody::Capability => cmd.capability().await, - CommandBody::Login { username, password } => cmd.login(username, password).await, - _ => Response::bad("Error in IMAP command received by server."), - } - }) - } -} -- cgit v1.2.3