pub struct DatasetManager { /* private fields */ }Expand description
High-level facade for dataset CRUD operations.
Wraps the low-level DB traits with optional ACL enforcement, matching
the Python SDK’s datasets class.
Implementations§
Source§impl DatasetManager
impl DatasetManager
Sourcepub fn new(db: Arc<dyn DatasetDb>) -> Self
pub fn new(db: Arc<dyn DatasetDb>) -> Self
Create a new DatasetManager without ACL enforcement.
Sourcepub fn with_acl(self, acl_db: Arc<dyn AclDb>) -> Self
pub fn with_acl(self, acl_db: Arc<dyn AclDb>) -> Self
Enable ACL enforcement using the given ACL database.
Sourcepub async fn list_datasets(
&self,
owner_id: Uuid,
) -> Result<Vec<Dataset>, DatasetError>
pub async fn list_datasets( &self, owner_id: Uuid, ) -> Result<Vec<Dataset>, DatasetError>
List all datasets accessible to the given owner.
When ACL is configured, only datasets the owner has “read” permission on are returned. Without ACL, all datasets owned by the user are listed.
Sourcepub async fn list_data(
&self,
dataset_id: Uuid,
owner_id: Uuid,
) -> Result<Vec<Data>, DatasetError>
pub async fn list_data( &self, dataset_id: Uuid, owner_id: Uuid, ) -> Result<Vec<Data>, DatasetError>
List all data items in a dataset, with permission check.
Results are sorted by data_size descending (largest first), matching
Python SDK behaviour.
Sourcepub async fn has_data(
&self,
dataset_id: Uuid,
owner_id: Uuid,
) -> Result<bool, DatasetError>
pub async fn has_data( &self, dataset_id: Uuid, owner_id: Uuid, ) -> Result<bool, DatasetError>
Check whether a dataset contains any data items.
Enforces read permission when ACL is configured, then uses an efficient COUNT query instead of loading all records.
Sourcepub async fn get_status(
&self,
dataset_ids: &[Uuid],
) -> Result<HashMap<Uuid, HashMap<String, PipelineRunStatus>>, DatasetError>
pub async fn get_status( &self, dataset_ids: &[Uuid], ) -> Result<HashMap<Uuid, HashMap<String, PipelineRunStatus>>, DatasetError>
Get the latest pipeline status for each dataset, across all tracked pipelines.
Returns a nested map { dataset_id → { pipeline_name → status } }.
Datasets with no pipeline runs for a given pipeline are omitted from the
inner map (equivalent to Python’s “not started” behaviour).
Sourcepub fn discover_datasets(
directory_path: &Path,
) -> Result<Vec<String>, DatasetError>
pub fn discover_datasets( directory_path: &Path, ) -> Result<Vec<String>, DatasetError>
Scan a filesystem directory for dataset-like sub-directories.
Returns the names of immediate child directories. This is a sync
utility matching the Python SDK’s discover_datasets method.
Sourcepub async fn empty_dataset(
&self,
dataset_id: Uuid,
owner_id: Uuid,
delete_service: &DeleteService,
) -> Result<DeleteResult, DatasetError>
pub async fn empty_dataset( &self, dataset_id: Uuid, owner_id: Uuid, delete_service: &DeleteService, ) -> Result<DeleteResult, DatasetError>
Delete all data in a dataset (and the dataset record itself).
Delegates to DeleteService with DeleteScope::Dataset.
Sourcepub async fn delete_data(
&self,
dataset_id: Uuid,
data_id: Uuid,
owner_id: Uuid,
mode: DeleteMode,
delete_dataset_if_empty: bool,
delete_service: &DeleteService,
) -> Result<DeleteResult, DatasetError>
pub async fn delete_data( &self, dataset_id: Uuid, data_id: Uuid, owner_id: Uuid, mode: DeleteMode, delete_dataset_if_empty: bool, delete_service: &DeleteService, ) -> Result<DeleteResult, DatasetError>
Delete a specific data item from a dataset.
Delegates to DeleteService with DeleteScope::Data.
Sourcepub async fn delete_all(
&self,
owner_id: Uuid,
delete_service: &DeleteService,
) -> Result<Vec<DeleteResult>, DatasetError>
pub async fn delete_all( &self, owner_id: Uuid, delete_service: &DeleteService, ) -> Result<Vec<DeleteResult>, DatasetError>
Delete all datasets for an owner.
Lists all accessible datasets and delegates each to DeleteService.
Sourcepub async fn create_dataset(
&self,
name: &str,
owner_id: Uuid,
tenant_id: Option<Uuid>,
) -> Result<Dataset, DatasetError>
pub async fn create_dataset( &self, name: &str, owner_id: Uuid, tenant_id: Option<Uuid>, ) -> Result<Dataset, DatasetError>
Create a dataset with a deterministic ID matching Python’s formula:
uuid5(NAMESPACE_OID, f"{name}{user_id}{tenant_id}").
Idempotent: if a dataset with the same deterministic ID already exists, returns the existing row.
Create a dataset and grant all four ACL permissions (read, write,
delete, share) to the owner.
Auto Trait Implementations§
impl !RefUnwindSafe for DatasetManager
impl !UnwindSafe for DatasetManager
impl Freeze for DatasetManager
impl Send for DatasetManager
impl Sync for DatasetManager
impl Unpin for DatasetManager
impl UnsafeUnpin for DatasetManager
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::RequestSource§impl<T, U, C> IntoWithContext<U, C> for Twhere
U: FromWithContext<T, C>,
impl<T, U, C> IntoWithContext<U, C> for Twhere
U: FromWithContext<T, C>,
Source§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> Read<Exclusive, BecauseExclusive> for Twhere
T: ?Sized,
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.