Struct Deleter

Source
pub struct Deleter { /* private fields */ }
Expand description

Deleter is designed to continuously remove content from storage.

It leverages batch deletion capabilities provided by storage services for efficient removal.

§Usage

Deleter provides several ways to delete files:

§Direct Deletion

Use the delete method to remove a single file:

use opendal::Operator;
use opendal::Result;

async fn example(op: Operator) -> Result<()> {
    let mut d = op.deleter().await?;
    d.delete("path/to/file").await?;
    d.close().await?;
    Ok(())
}

Delete multiple files via a stream:

use futures::stream;
use opendal::Operator;
use opendal::Result;

async fn example(op: Operator) -> Result<()> {
    let mut d = op.deleter().await?;
    d.delete_stream(stream::iter(vec!["path/to/file"])).await?;
    d.close().await?;
    Ok(())
}

§Using as a Sink

Deleter can be used as a Sink for file deletion:

use futures::stream;
use futures::Sink;
use futures::SinkExt;
use opendal::Operator;
use opendal::Result;

async fn example(op: Operator) -> Result<()> {
    let mut sink = op.deleter().await?.into_sink();
    sink.send("path/to/file").await?;
    sink.close().await?;
    Ok(())
}

Implementations§

Source§

impl Deleter

Source

pub async fn delete(&mut self, input: impl IntoDeleteInput) -> Result<()>

Delete a path.

Source

pub async fn delete_iter<I, D>(&mut self, iter: I) -> Result<()>
where I: IntoIterator<Item = D>, D: IntoDeleteInput,

Delete an infallible iterator of paths.

Also see:

Source

pub async fn delete_try_iter<I, D>(&mut self, try_iter: I) -> Result<()>
where I: IntoIterator<Item = Result<D>>, D: IntoDeleteInput,

Delete a fallible iterator of paths.

Also see:

Source

pub async fn delete_stream<S, D>(&mut self, stream: S) -> Result<()>
where S: Stream<Item = D>, D: IntoDeleteInput,

Delete an infallible stream of paths.

Also see:

Source

pub async fn delete_try_stream<S, D>(&mut self, try_stream: S) -> Result<()>
where S: Stream<Item = Result<D>>, D: IntoDeleteInput,

Delete a fallible stream of paths.

Also see:

Source

pub async fn flush(&mut self) -> Result<usize>

Flush the deleter, returns the number of deleted paths.

Source

pub async fn close(&mut self) -> Result<()>

Close the deleter, this will flush the deleter and wait until all paths are deleted.

Source

pub fn into_sink<T: IntoDeleteInput>(self) -> FuturesDeleteSink<T>

Convert the deleter into a sink.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ServiceExt for T

Source§

fn map_response_body<F>(self, f: F) -> MapResponseBody<Self, F>
where Self: Sized,

Apply a transformation to the response body. Read more
Source§

fn decompression(self) -> Decompression<Self>
where Self: Sized,

Decompress response bodies. Read more
Source§

fn trace_for_http(self) -> Trace<Self, SharedClassifier<ServerErrorsAsFailures>>
where Self: Sized,

High level tracing that classifies responses using HTTP status codes. Read more
Source§

fn trace_for_grpc(self) -> Trace<Self, SharedClassifier<GrpcErrorsAsFailures>>
where Self: Sized,

High level tracing that classifies responses using gRPC headers. Read more
Source§

fn follow_redirects(self) -> FollowRedirect<Self>
where Self: Sized,

Follow redirect resposes using the Standard policy. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> MaybeSend for T
where T: Send,