diff options
author | Quentin Dufour <quentin@deuxfleurs.fr> | 2022-06-07 13:46:13 +0200 |
---|---|---|
committer | Quentin Dufour <quentin@deuxfleurs.fr> | 2022-06-07 13:46:13 +0200 |
commit | cbcc339d50fc2c30e51776c3a60818190ffb4f23 (patch) | |
tree | 268938d6c45b1323cea34949c6712f544d9ac00e | |
parent | 93f943aa802163eb47feef592c1504112e4588c5 (diff) | |
download | aerogramme-cbcc339d50fc2c30e51776c3a60818190ffb4f23.tar.gz aerogramme-cbcc339d50fc2c30e51776c3a60818190ffb4f23.zip |
Start implementing other endpoints
-rw-r--r-- | src/command.rs | 22 | ||||
-rw-r--r-- | src/mailbox.rs | 2 | ||||
-rw-r--r-- | src/service.rs | 4 |
3 files changed, 21 insertions, 7 deletions
diff --git a/src/command.rs b/src/command.rs index 2ee1a07..9b2f12d 100644 --- a/src/command.rs +++ b/src/command.rs @@ -4,11 +4,12 @@ use boitalettres::errors::Error as BalError; use boitalettres::proto::{Request, Response}; use imap_codec::types::core::{Tag, AString}; use imap_codec::types::response::{Capability, Data}; -use imap_codec::types::mailbox::{Mailbox, ListMailbox}; +use imap_codec::types::mailbox::{Mailbox as MailboxCodec, ListMailbox}; use imap_codec::types::sequence::SequenceSet; use imap_codec::types::fetch_attributes::MacroOrFetchAttributes; use crate::mailstore::Mailstore; +use crate::mailbox::Mailbox; use crate::service::Session; pub struct Command { @@ -43,23 +44,34 @@ impl Command { }; let mut session = match self.session.lock() { - Err(_) => return Response::bad("[AUTHENTICATIONFAILED] Unable to acquire mutex."), + Err(_) => return Response::bad("[AUTHENTICATIONFAILED] Unable to acquire lock on session."), Ok(s) => s, }; session.creds = Some(creds); + drop(session); Response::ok("Logged in") } - pub async fn lsub(&self, reference: Mailbox, mailbox_wildcard: ListMailbox) -> Result<Response, BalError> { + pub async fn lsub(&self, reference: MailboxCodec, mailbox_wildcard: ListMailbox) -> Result<Response, BalError> { Response::bad("Not implemented") } - pub async fn list(&self, reference: Mailbox, mailbox_wildcard: ListMailbox) -> Result<Response, BalError> { + pub async fn list(&self, reference: MailboxCodec, mailbox_wildcard: ListMailbox) -> Result<Response, BalError> { Response::bad("Not implemented") } - pub async fn select(&self, mailbox: Mailbox) -> Result<Response, BalError> { + pub async fn select(&self, mailbox: MailboxCodec) -> Result<Response, BalError> { + + let mut session = match self.session.lock() { + Err(_) => return Response::no("[SELECTFAILED] Unable to acquire lock on session."), + Ok(s) => s, + }; + + let mb = Mailbox::new(session.creds.as_ref().unwrap(), "TestMailbox".to_string()).unwrap(); + session.selected = Some(mb); + drop(session); + Response::bad("Not implemented") } diff --git a/src/mailbox.rs b/src/mailbox.rs index a20ca15..204b487 100644 --- a/src/mailbox.rs +++ b/src/mailbox.rs @@ -20,7 +20,7 @@ pub struct Mailbox { } impl Mailbox { - pub async fn new(creds: &Credentials, name: String) -> Result<Self> { + pub fn new(creds: &Credentials, name: String) -> Result<Self> { let uid_index = Bayou::<UidIndex>::new(creds, name.clone())?; Ok(Self { diff --git a/src/service.rs b/src/service.rs index 4d4c288..a2fca4d 100644 --- a/src/service.rs +++ b/src/service.rs @@ -12,6 +12,7 @@ use tower::Service; use crate::command; use crate::login::Credentials; use crate::mailstore::Mailstore; +use crate::mailbox::Mailbox; pub struct Instance { pub mailstore: Arc<Mailstore>, @@ -39,6 +40,7 @@ impl<'a> Service<&'a AddrStream> for Instance { pub struct Session { pub creds: Option<Credentials>, + pub selected: Option<Mailbox>, } pub struct Connection { @@ -47,7 +49,7 @@ pub struct Connection { } impl Connection { pub fn new(mailstore: Arc<Mailstore>) -> Self { - Self { mailstore, session: Arc::new(Mutex::new(Session { creds: None })) } + Self { mailstore, session: Arc::new(Mutex::new(Session { creds: None, selected: None, })) } } } impl Service<Request> for Connection { |