Struct vstorage::sync::plan::Plan

source ·
pub struct Plan<I: Item> {
    pub collection_plans: Vec<CollectionPlan<I>>,
    /* private fields */
}
Expand description

Actions that would synchronise a pair of storages.

Use Plan::new to create new instances.

Use Plan::collection_plans) to inspect the plan and render it into a human-friendly representation, into a CSV, or into any other format that is necessary.

Use Plan::execute to execute this plan and apply changes to the provided Storage instances.

Fields§

§collection_plans: Vec<CollectionPlan<I>>

Implementations§

source§

impl<I: Item> Plan<I>

source

pub async fn execute( self, status: &StatusDatabase, on_error: impl Fn(SyncError<I>), ) -> Result<(), StatusError>

Executes a synchronization plan.

§Non-fatal errors

When a non-fatal error occurs (e.g.: an item being uploaded is rejected), the on_error function will be called with details on the exact error.

§Errors

A StatusError is returned in case writing to the status database fails.

source§

impl<I: Item> Plan<I>

source

pub async fn new( pair: &StoragePair<I>, status: Option<&StatusDatabase>, ) -> Result<Plan<I>, PlanError>

Create a new plan for a given storage pair.

§Errors

Returns an error if:

  • There is an error discovering remote collections.
  • A mapping is defined by collection id, but the id is invalid for the underlying storage.
  • There is an error reading the state of existing items.
  • The same collection is mapped more than once.
source

pub fn storage_a(&self) -> &dyn Storage<I>

source

pub fn storage_b(&self) -> &dyn Storage<I>

Trait Implementations§

source§

impl<I: Item> Debug for Plan<I>

Show details of the plan itself.

This is partially necessary because storages don’t yet implement Debug .

source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<I> Freeze for Plan<I>

§

impl<I> !RefUnwindSafe for Plan<I>

§

impl<I> Send for Plan<I>

§

impl<I> Sync for Plan<I>

§

impl<I> Unpin for Plan<I>
where <I as Item>::Property: Unpin, I: Unpin,

§

impl<I> !UnwindSafe for Plan<I>

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<Source, Target> OctetsInto<Target> for Source
where Target: OctetsFrom<Source>,

source§

type Error = <Target as OctetsFrom<Source>>::Error

source§

fn try_octets_into( self, ) -> Result<Target, <Source as OctetsInto<Target>>::Error>

Performs the conversion.
source§

fn octets_into(self) -> Target
where Self::Error: Into<Infallible>,

Performs an infallible conversion.
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
source§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

source§

type Output = T

Should always be Self
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