diff options
author | Quentin Dufour <quentin@deuxfleurs.fr> | 2023-11-02 09:42:50 +0100 |
---|---|---|
committer | Quentin Dufour <quentin@deuxfleurs.fr> | 2023-11-02 09:42:50 +0100 |
commit | 26f14df3f460320b2e2d31deb9d3cef90f43790c (patch) | |
tree | 377fa4a978ffe0e82b1ddba5c2009befb6f80fc7 /src | |
parent | cf8b9ac28d6813bd589f363ad3659dd215bd7cea (diff) | |
download | aerogramme-26f14df3f460320b2e2d31deb9d3cef90f43790c.tar.gz aerogramme-26f14df3f460320b2e2d31deb9d3cef90f43790c.zip |
we are doomed with static types
Diffstat (limited to 'src')
-rw-r--r-- | src/mail/incoming.rs | 5 | ||||
-rw-r--r-- | src/mail/user.rs | 2 | ||||
-rw-r--r-- | src/storage/mod.rs | 6 |
3 files changed, 6 insertions, 7 deletions
diff --git a/src/mail/incoming.rs b/src/mail/incoming.rs index b7d2f48..7094b42 100644 --- a/src/mail/incoming.rs +++ b/src/mail/incoming.rs @@ -23,6 +23,7 @@ use crate::mail::unique_ident::*; use crate::mail::user::User; use crate::mail::IMF; use crate::time::now_msec; +use crate::storage::Sto; const INCOMING_PK: &str = "incoming"; const INCOMING_LOCK_SK: &str = "lock"; @@ -139,14 +140,14 @@ async fn incoming_mail_watch_process_internal( Ok(()) } -async fn handle_incoming_mail( +async fn handle_incoming_mail<X: Sto>( user: &Arc<User>, s3: &S3Client, inbox: &Arc<Mailbox>, lock_held: &watch::Receiver<bool>, ) -> Result<()> { let lor = ListObjectsV2Request { - bucket: user.creds.storage.bucket.clone(), + bucket: user.creds.storage.engine::<X>().bucket.clone(), max_keys: Some(1000), prefix: Some("incoming/".into()), ..Default::default() diff --git a/src/mail/user.rs b/src/mail/user.rs index 360786d..5523c2a 100644 --- a/src/mail/user.rs +++ b/src/mail/user.rs @@ -30,8 +30,6 @@ pub const INBOX: &str = "INBOX"; const MAILBOX_LIST_PK: &str = "mailboxes"; const MAILBOX_LIST_SK: &str = "list"; -use crate::storage::*; - pub struct User { pub username: String, pub creds: Credentials, diff --git a/src/storage/mod.rs b/src/storage/mod.rs index c0835e6..ee475ee 100644 --- a/src/storage/mod.rs +++ b/src/storage/mod.rs @@ -36,8 +36,8 @@ pub trait Sto: Sized { } pub struct Engine<T: Sto> { - bucket: String, - row: T::Builder, + pub bucket: String, + pub row: T::Builder, } pub enum AnyEngine { @@ -45,7 +45,7 @@ pub enum AnyEngine { Garage(Engine<garage::GrgTypes>), } impl AnyEngine { - fn engine<X: Sto>(&self) -> &Engine<X> { + pub fn engine<X: Sto>(&self) -> &Engine<X> { match self { Self::InMemory(x) => x, Self::Garage(x) => x, |