Struct ListBlobsRequest

Source
pub struct ListBlobsRequest {
    pub include_dirs: bool,
    pub extensions: HashSet<String>,
    pub excluded: HashSet<String>,
    pub prefix: Option<String>,
}
Expand description

Represents the request options for querying blobs from a storage service.

Fieldsยง

ยงinclude_dirs: bool

Whether if the response should include directory blobs or not. If this set to false, then it will only include file blobs in the given directory where the request is being processed.

ยงextensions: HashSet<String>

A list of extensions to filter for. By default, this will include all file extensions if no entries exist.

ยงexcluded: HashSet<String>

List of file names to exclude from the returned entry. This can exclude directories with the dir: prefix.

ยงprefix: Option<String>

Optional prefix to set when querying for blobs.

Implementationsยง

Sourceยง

impl ListBlobsRequest

Source

pub fn exclude<'a, I: Iterator<Item = &'a str>>(self, items: I) -> Self

Appends a slice of strings to exclude from.

Source

pub fn with_prefix<I: Into<String>>(self, prefix: Option<I>) -> Self

Sets a prefix to this request.

Source

pub fn with_extensions<'a, I: Iterator<Item = &'a str>>(self, exts: I) -> Self

Appends a list of extensions that can be use to filter files from in the given directory that items were found.

Source

pub fn with_include_dirs(&mut self, yes: bool) -> &mut Self

Whether if the response should include directory blobs or not. If this set to false, then it will only include file blobs in the given directory where the request is being processed.

Source

pub fn is_excluded<I: AsRef<str>>(&self, item: I) -> bool

Checks if the given item is excluded or not.

ยงExample
โ“˜
let mut req = ListBlobsRequest::default();
let _ = req.clone().exclude(&["hello.txt"]);

assert!(!req.is_excluded("world.txt"));
assert!(req.is_excluded("hello.txt"));
Source

pub fn is_ext_allowed<I: AsRef<str>>(&self, ext: I) -> bool

Checks if an extension is allowed. If the configured extensions to return is empty, then this will always return true. Otherwise, it will try to check if it exists or not.

ยงExample
โ“˜
let mut req = ListBlobsRequest::default();
let _ = req.clone().extensions(&[".txt"]);

assert!(!req.is_ext_allowed(".json"));
assert!(req.is_ext_allowed(".txt"));

let req = ListBlobsRequest::default();
assert!(req.is_ext_allowed(".json"));

Trait Implementationsยง

Sourceยง

impl Clone for ListBlobsRequest

Sourceยง

fn clone(&self) -> ListBlobsRequest

Returns a duplicate of the value. Read more
1.0.0 ยท Sourceยง

const fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Sourceยง

impl Debug for ListBlobsRequest

Sourceยง

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Sourceยง

impl Default for ListBlobsRequest

Sourceยง

fn default() -> ListBlobsRequest

Returns the โ€œdefault valueโ€ for a type. Read more

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> CloneToUninit for T
where T: Clone,

Sourceยง

unsafe fn clone_to_uninit(&self, dest: *mut u8)

๐Ÿ”ฌThis is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Sourceยง

impl<T> From<T> for T

Sourceยง

fn from(t: T) -> T

Returns the argument unchanged.

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> ToOwned for T
where T: Clone,

Sourceยง

type Owned = T

The resulting type after obtaining ownership.
Sourceยง

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Sourceยง

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.