use std::borrow::Cow;
use std::future::IntoFuture;
use std::marker::PhantomData;
use std::path::PathBuf;
use crate::conn::Command;
use crate::method::{BoxFuture, Model, OnceLockExt};
use crate::{Connection, Error, ExtraFeatures, Result, Surreal};
#[derive(Debug)]
#[must_use = "futures do nothing unless you `.await` or poll them"]
pub struct Import<'r, C: Connection, T = ()> {
pub(super) client: Cow<'r, Surreal<C>>,
pub(super) file: PathBuf,
pub(super) is_ml: bool,
pub(super) import_type: PhantomData<T>,
}
impl<'r, C> Import<'r, C>
where
C: Connection,
{
pub fn ml(self) -> Import<'r, C, Model> {
Import {
client: self.client,
file: self.file,
is_ml: true,
import_type: PhantomData,
}
}
}
impl<C, T> Import<'_, C, T>
where
C: Connection,
{
pub fn into_owned(self) -> Import<'static, C, T> {
Import {
client: Cow::Owned(self.client.into_owned()),
..self
}
}
}
impl<'r, Client, T> IntoFuture for Import<'r, Client, T>
where
Client: Connection,
{
type Output = Result<()>;
type IntoFuture = BoxFuture<'r, Self::Output>;
fn into_future(self) -> Self::IntoFuture {
Box::pin(async move {
let router = self.client.inner.router.extract()?;
if !router.features.contains(&ExtraFeatures::Backup) {
return Err(Error::internal(
"The protocol or storage engine does not support backups on this architecture"
.to_string(),
));
}
if self.is_ml {
return router
.execute_unit(
self.client.session_id,
Command::ImportMl {
path: self.file,
},
)
.await;
}
router
.execute_unit(
self.client.session_id,
Command::ImportFile {
path: self.file,
},
)
.await
})
}
}