pub struct Bucket {
    pub id: Uuid,
    pub state: Deletable<BucketParams>,
}
Expand description

A bucket is a collection of objects

Its parameters are not directly accessible as:

  • It must be possible to merge paramaters, hence the use of a LWW CRDT.
  • A bucket has 2 states, Present or Deleted and parameters make sense only if present.

Fields§

§id: Uuid

ID of the bucket

§state: Deletable<BucketParams>

State, and configuration if not deleted, of the bucket

Implementations§

source§

impl Bucket

source

pub fn new() -> Self

Initializes a new instance of the Bucket struct

source

pub fn present(id: Uuid, params: BucketParams) -> Self

source

pub fn is_deleted(&self) -> bool

Returns true if this represents a deleted bucket

source

pub fn params(&self) -> Option<&BucketParams>

Returns an option representing the parameters (None if in deleted state)

source

pub fn params_mut(&mut self) -> Option<&mut BucketParams>

Mutable version of .params()

source

pub fn authorized_keys(&self) -> &[(String, BucketKeyPerm)]

Return the list of authorized keys, when each was updated, and the permission associated to the key

source

pub fn aliases(&self) -> &[(String, u64, bool)]

source

pub fn local_aliases(&self) -> &[((String, String), u64, bool)]

Trait Implementations§

source§

impl Clone for Bucket

source§

fn clone(&self) -> Bucket

Returns a copy of the value. Read more
1.0.0 · source§

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

Performs copy-assignment from source. Read more
source§

impl Crdt for Bucket

source§

fn merge(&mut self, other: &Self)

Merge the two datastructures according to the CRDT rules. self is modified to contain the merged CRDT value. other is not modified. Read more
source§

impl Debug for Bucket

source§

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

Formats the value using the given formatter. Read more
source§

impl Default for Bucket

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl<'de> Deserialize<'de> for Bucket

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl Entry<EmptyKey, FixedBytes32> for Bucket

source§

fn partition_key(&self) -> &EmptyKey

Get the key used to partition
source§

fn sort_key(&self) -> &Uuid

Get the key used to sort
source§

fn is_tombstone(&self) -> bool

Is the entry a tombstone? Default implementation always return false
source§

impl InitialFormat for Bucket

source§

const VERSION_MARKER: &'static [u8] = b""

A sequence of bytes to add at the beginning of the serialized string, to identify that the data is of this version.
source§

impl PartialEq for Bucket

source§

fn eq(&self, other: &Bucket) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Serialize for Bucket

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl Eq for Bucket

source§

impl StructuralPartialEq for Bucket

Auto Trait Implementations§

§

impl Freeze for Bucket

§

impl RefUnwindSafe for Bucket

§

impl Send for Bucket

§

impl Sync for Bucket

§

impl Unpin for Bucket

§

impl UnwindSafe for Bucket

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<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FutureExt for T

source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
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> Migrate for T
where T: InitialFormat,

source§

const VERSION_MARKER: &'static [u8] = <T as InitialFormat>::VERSION_MARKER

A sequence of bytes to add at the beginning of the serialized string, to identify that the data is of this version.
§

type Previous = NoPrevious

The previous version of this data type, from which items of this version can be migrated.
source§

fn migrate(_previous: <T as Migrate>::Previous) -> T

The migration function that transforms a value decoded in the old format to an up-to-date value.
source§

fn decode(bytes: &[u8]) -> Option<Self>

Decode an encoded version of this type, going through a migration if necessary.
source§

fn encode(&self) -> Result<Vec<u8>, Error>

Encode this type with optional version marker
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

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>,

§

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>,

§

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> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,