in-memory storage #32
5 changed files with 46 additions and 33 deletions
|
@ -39,7 +39,7 @@ pub type ArcLoginProvider = Arc<dyn LoginProvider + Send + Sync>;
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
pub struct Credentials {
|
pub struct Credentials {
|
||||||
/// The storage credentials are used to authenticate access to the underlying storage (S3, K2V)
|
/// The storage credentials are used to authenticate access to the underlying storage (S3, K2V)
|
||||||
pub storage: Engine,
|
pub storage: Builders,
|
||||||
/// The cryptographic keys are used to encrypt and decrypt data stored in S3 and K2V
|
/// The cryptographic keys are used to encrypt and decrypt data stored in S3 and K2V
|
||||||
pub keys: CryptoKeys,
|
pub keys: CryptoKeys,
|
||||||
}
|
}
|
||||||
|
@ -109,14 +109,11 @@ impl Region {
|
||||||
|
|
||||||
|
|
||||||
impl Credentials {
|
impl Credentials {
|
||||||
pub fn k2v_client(&self) -> Result<RowStore> {
|
pub fn row_client(&self) -> Result<RowStore> {
|
||||||
self.storage.row.row_store()
|
Ok(self.storage.row_store()?)
|
||||||
}
|
}
|
||||||
pub fn s3_client(&self) -> Result<S3Client> {
|
pub fn blob_client(&self) -> Result<BlobStore> {
|
||||||
self.storage.s3_client()
|
Ok(self.storage.blob_store()?)
|
||||||
}
|
|
||||||
pub fn bucket(&self) -> &str {
|
|
||||||
self.storage.bucket.as_str()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,6 +13,7 @@ use crate::mail::incoming::incoming_mail_watch_process;
|
||||||
use crate::mail::mailbox::Mailbox;
|
use crate::mail::mailbox::Mailbox;
|
||||||
use crate::mail::uidindex::ImapUidvalidity;
|
use crate::mail::uidindex::ImapUidvalidity;
|
||||||
use crate::mail::unique_ident::{gen_ident, UniqueIdent};
|
use crate::mail::unique_ident::{gen_ident, UniqueIdent};
|
||||||
|
use crate::storage;
|
||||||
use crate::time::now_msec;
|
use crate::time::now_msec;
|
||||||
|
|
||||||
pub const MAILBOX_HIERARCHY_DELIMITER: char = '.';
|
pub const MAILBOX_HIERARCHY_DELIMITER: char = '.';
|
||||||
|
@ -455,6 +456,6 @@ enum CreatedMailbox {
|
||||||
// ---- User cache ----
|
// ---- User cache ----
|
||||||
|
|
||||||
lazy_static! {
|
lazy_static! {
|
||||||
static ref USER_CACHE: std::sync::Mutex<HashMap<(String, StorageCredentials), Weak<User>>> =
|
static ref USER_CACHE: std::sync::Mutex<HashMap<(String, storage::Builders), Weak<User>>> =
|
||||||
std::sync::Mutex::new(HashMap::new());
|
std::sync::Mutex::new(HashMap::new());
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
use crate::storage::*;
|
use crate::storage::*;
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug, Hash)]
|
||||||
pub struct GrgCreds {}
|
pub struct GrgCreds {}
|
||||||
pub struct GrgStore {}
|
pub struct GrgStore {}
|
||||||
pub struct GrgRef {}
|
pub struct GrgRef {}
|
||||||
pub struct GrgValue {}
|
pub struct GrgValue {}
|
||||||
|
|
||||||
impl IBuilder for GrgCreds {
|
impl IBuilders for GrgCreds {
|
||||||
fn row_store(&self) -> Result<RowStore, StorageError> {
|
fn row_store(&self) -> Result<RowStore, StorageError> {
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,10 @@ impl IBuilder for GrgCreds {
|
||||||
fn blob_store(&self) -> Result<BlobStore, StorageError> {
|
fn blob_store(&self) -> Result<BlobStore, StorageError> {
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn url(&self) -> &str {
|
||||||
|
return "grg://unimplemented;"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl IRowStore for GrgStore {
|
impl IRowStore for GrgStore {
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
use futures::FutureExt;
|
use futures::FutureExt;
|
||||||
use crate::storage::*;
|
use crate::storage::*;
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug, Hash)]
|
||||||
pub struct FullMem {}
|
pub struct FullMem {}
|
||||||
pub struct MemStore {}
|
pub struct MemStore {}
|
||||||
pub struct MemRef {}
|
pub struct MemRef {}
|
||||||
pub struct MemValue {}
|
pub struct MemValue {}
|
||||||
|
|
||||||
impl IBuilder for FullMem {
|
impl IBuilders for FullMem {
|
||||||
fn row_store(&self) -> Result<RowStore, StorageError> {
|
fn row_store(&self) -> Result<RowStore, StorageError> {
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
@ -15,6 +15,10 @@ impl IBuilder for FullMem {
|
||||||
fn blob_store(&self) -> Result<BlobStore, StorageError> {
|
fn blob_store(&self) -> Result<BlobStore, StorageError> {
|
||||||
unimplemented!();
|
unimplemented!();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn url(&self) -> &str {
|
||||||
|
return "mem://unimplemented;"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl IRowStore for MemStore {
|
impl IRowStore for MemStore {
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
* into the object system so it is not exposed.
|
* into the object system so it is not exposed.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
use std::hash::{Hash, Hasher};
|
||||||
use futures::future::BoxFuture;
|
use futures::future::BoxFuture;
|
||||||
|
|
||||||
pub mod in_memory;
|
pub mod in_memory;
|
||||||
|
@ -40,32 +41,38 @@ impl std::fmt::Display for StorageError {
|
||||||
}
|
}
|
||||||
impl std::error::Error for StorageError {}
|
impl std::error::Error for StorageError {}
|
||||||
|
|
||||||
pub struct Engine {
|
|
||||||
pub bucket: String,
|
|
||||||
pub builders: Builder,
|
|
||||||
}
|
|
||||||
impl Clone for Engine {
|
|
||||||
fn clone(&self) -> Self {
|
|
||||||
Engine {
|
|
||||||
bucket: "test".into(),
|
|
||||||
builders: Box::new(in_memory::FullMem{})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
impl std::fmt::Debug for Engine {
|
|
||||||
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
|
||||||
f.debug_struct("Engine").field("bucket", &self.bucket).finish()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Utils
|
// Utils
|
||||||
pub type AsyncResult<'a, T> = BoxFuture<'a, Result<T, StorageError>>;
|
pub type AsyncResult<'a, T> = BoxFuture<'a, Result<T, StorageError>>;
|
||||||
|
|
||||||
pub trait IBuilder {
|
// ----- Builders
|
||||||
|
pub trait IBuilders {
|
||||||
fn row_store(&self) -> Result<RowStore, StorageError>;
|
fn row_store(&self) -> Result<RowStore, StorageError>;
|
||||||
fn blob_store(&self) -> Result<BlobStore, StorageError>;
|
fn blob_store(&self) -> Result<BlobStore, StorageError>;
|
||||||
|
fn url(&self) -> &str;
|
||||||
|
}
|
||||||
|
pub type Builders = Box<dyn IBuilders + Send + Sync>;
|
||||||
|
impl Clone for Builders {
|
||||||
|
fn clone(&self) -> Self {
|
||||||
|
// @FIXME write a real implementation with a box_clone function
|
||||||
|
Box::new(in_memory::FullMem{})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
impl std::fmt::Debug for Builders {
|
||||||
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
|
f.write_str("aerogramme::storage::Builder")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
impl PartialEq for Builders {
|
||||||
|
fn eq(&self, other: &Self) -> bool {
|
||||||
|
self.url() == other.url()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
impl Eq for Builders {}
|
||||||
|
impl Hash for Builders {
|
||||||
|
fn hash<H: Hasher>(&self, state: &mut H) {
|
||||||
|
self.url().hash(state);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
pub type Builder = Box<dyn IBuilder + Send + Sync>;
|
|
||||||
|
|
||||||
// ------ Row
|
// ------ Row
|
||||||
pub trait IRowStore
|
pub trait IRowStore
|
||||||
|
|
Loading…
Reference in a new issue