2021-10-23 04:48:56 +00:00
|
|
|
use std::fmt::Debug;
|
|
|
|
|
|
|
|
use actix_web::web::Bytes;
|
|
|
|
use futures_util::stream::Stream;
|
|
|
|
use tokio::io::{AsyncRead, AsyncWrite};
|
|
|
|
|
|
|
|
pub(crate) mod file_store;
|
2021-10-28 04:06:03 +00:00
|
|
|
#[cfg(feature = "object-storage")]
|
|
|
|
pub(crate) mod object_store;
|
2021-10-23 04:48:56 +00:00
|
|
|
|
|
|
|
pub(crate) trait Identifier: Send + Sync + Clone + Debug {
|
|
|
|
type Error: std::error::Error;
|
|
|
|
|
|
|
|
fn to_bytes(&self) -> Result<Vec<u8>, Self::Error>;
|
|
|
|
|
|
|
|
fn from_bytes(bytes: Vec<u8>) -> Result<Self, Self::Error>
|
|
|
|
where
|
|
|
|
Self: Sized;
|
|
|
|
}
|
|
|
|
|
|
|
|
#[async_trait::async_trait(?Send)]
|
|
|
|
pub(crate) trait Store: Send + Sync + Clone + Debug + 'static {
|
|
|
|
type Error: std::error::Error;
|
|
|
|
type Identifier: Identifier<Error = Self::Error>;
|
|
|
|
type Stream: Stream<Item = std::io::Result<Bytes>>;
|
|
|
|
|
|
|
|
async fn save_async_read<Reader>(
|
|
|
|
&self,
|
|
|
|
reader: &mut Reader,
|
2021-11-16 15:45:16 +00:00
|
|
|
filename: &str,
|
2021-10-23 04:48:56 +00:00
|
|
|
) -> Result<Self::Identifier, Self::Error>
|
|
|
|
where
|
|
|
|
Reader: AsyncRead + Unpin;
|
|
|
|
|
2021-11-16 15:45:16 +00:00
|
|
|
async fn save_bytes(
|
|
|
|
&self,
|
|
|
|
bytes: Bytes,
|
|
|
|
filename: &str,
|
|
|
|
) -> Result<Self::Identifier, Self::Error>;
|
2021-10-23 04:48:56 +00:00
|
|
|
|
|
|
|
async fn to_stream(
|
|
|
|
&self,
|
|
|
|
identifier: &Self::Identifier,
|
|
|
|
from_start: Option<u64>,
|
|
|
|
len: Option<u64>,
|
|
|
|
) -> Result<Self::Stream, Self::Error>;
|
|
|
|
|
|
|
|
async fn read_into<Writer>(
|
|
|
|
&self,
|
|
|
|
identifier: &Self::Identifier,
|
|
|
|
writer: &mut Writer,
|
|
|
|
) -> Result<(), std::io::Error>
|
|
|
|
where
|
2021-10-31 17:35:11 +00:00
|
|
|
Writer: AsyncWrite + Send + Unpin;
|
2021-10-23 04:48:56 +00:00
|
|
|
|
|
|
|
async fn len(&self, identifier: &Self::Identifier) -> Result<u64, Self::Error>;
|
|
|
|
|
|
|
|
async fn remove(&self, identifier: &Self::Identifier) -> Result<(), Self::Error>;
|
|
|
|
}
|