2023-06-25 15:51:05 +00:00
|
|
|
use crate::error::unexpected::Mappable;
|
2023-07-16 14:09:37 +00:00
|
|
|
use crate::{origin, util};
|
2023-06-25 15:51:05 +00:00
|
|
|
|
2023-06-29 14:54:55 +00:00
|
|
|
pub struct Store<F, S>
|
2023-06-25 15:51:05 +00:00
|
|
|
where
|
2024-01-21 15:18:31 +00:00
|
|
|
S: origin::Store + Sync + Send + 'static,
|
2023-06-25 15:51:05 +00:00
|
|
|
F: Fn(&origin::Descr) -> Option<S> + Sync + Send,
|
|
|
|
{
|
|
|
|
mapping_fn: F,
|
|
|
|
stores: Vec<S>,
|
|
|
|
}
|
|
|
|
|
2023-06-29 14:54:55 +00:00
|
|
|
impl<F, S> Store<F, S>
|
2023-06-25 15:51:05 +00:00
|
|
|
where
|
2024-01-21 15:18:31 +00:00
|
|
|
S: origin::Store + Sync + Send + 'static,
|
2023-06-29 14:54:55 +00:00
|
|
|
F: Fn(&origin::Descr) -> Option<S> + Sync + Send,
|
2023-06-25 15:51:05 +00:00
|
|
|
{
|
2023-06-29 14:54:55 +00:00
|
|
|
pub fn new(mapping_fn: F, stores: Vec<S>) -> Store<F, S> {
|
|
|
|
Store { mapping_fn, stores }
|
|
|
|
}
|
2023-06-25 15:51:05 +00:00
|
|
|
}
|
|
|
|
|
2023-07-05 17:03:51 +00:00
|
|
|
impl<F, S> origin::Store for Store<F, S>
|
2023-06-25 15:51:05 +00:00
|
|
|
where
|
2024-01-21 15:18:31 +00:00
|
|
|
S: origin::Store + Sync + Send + 'static,
|
2023-06-25 15:51:05 +00:00
|
|
|
F: Fn(&origin::Descr) -> Option<S> + Sync + Send,
|
|
|
|
{
|
2024-01-21 15:18:31 +00:00
|
|
|
fn sync(&self, descr: &origin::Descr) -> util::BoxFuture<'_, Result<(), origin::SyncError>> {
|
|
|
|
let descr = descr.clone();
|
|
|
|
Box::pin(async move {
|
|
|
|
(self.mapping_fn)(&descr)
|
|
|
|
.or_unexpected_while(format!("mapping {:?} to store", &descr))?
|
|
|
|
.sync(&descr)
|
|
|
|
.await
|
|
|
|
})
|
2023-06-25 15:51:05 +00:00
|
|
|
}
|
|
|
|
|
2023-07-05 17:03:51 +00:00
|
|
|
fn all_descrs(&self) -> Result<Vec<origin::Descr>, origin::AllDescrsError> {
|
2023-06-25 15:51:05 +00:00
|
|
|
let mut res = Vec::<origin::Descr>::new();
|
|
|
|
|
|
|
|
for store in self.stores.iter() {
|
|
|
|
store.all_descrs()?.into_iter().collect_into(&mut res);
|
|
|
|
}
|
|
|
|
|
|
|
|
Ok(res)
|
|
|
|
}
|
2023-07-05 17:03:51 +00:00
|
|
|
|
2024-01-10 09:42:48 +00:00
|
|
|
fn get_file(
|
|
|
|
&self,
|
2023-07-16 14:09:37 +00:00
|
|
|
descr: &origin::Descr,
|
|
|
|
path: &str,
|
|
|
|
) -> Result<util::BoxByteStream, origin::GetFileError> {
|
2023-07-06 17:19:51 +00:00
|
|
|
(self.mapping_fn)(descr)
|
2023-07-16 14:09:37 +00:00
|
|
|
.or_unexpected_while(format!("mapping {:?} to store", &descr))?
|
|
|
|
.get_file(descr, path)
|
2023-07-06 17:19:51 +00:00
|
|
|
}
|
2023-06-25 15:51:05 +00:00
|
|
|
}
|