pub struct Priority<DS> {
instance_name: String,
services: BTreeMap<Prio, DS>,
}Expand description
Holds references to many different directory services, each with an associated priority. Read requests try services sequentially, sorted by their priority, ascending. Any error in a service bubbles up. Write requests are not implemented.
Fields§
§instance_name: String§services: BTreeMap<Prio, DS>The services, keyed by their priority.
Implementations§
Trait Implementations§
Source§impl<DS> DirectoryService for Priority<DS>where
DS: DirectoryService,
impl<DS> DirectoryService for Priority<DS>where
DS: DirectoryService,
Source§fn get<'life0, 'life1, 'async_trait>(
&'life0 self,
digest: &'life1 B3Digest,
) -> Pin<Box<dyn Future<Output = Result<Option<Directory>, Error>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn get<'life0, 'life1, 'async_trait>(
&'life0 self,
digest: &'life1 B3Digest,
) -> Pin<Box<dyn Future<Output = Result<Option<Directory>, Error>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Looks up a single Directory message by its digest.
The returned Directory message must be valid.
In case the directory is not found, Ok(None) is returned. Read more
Source§fn get_recursive(
&self,
root_directory_digest: &B3Digest,
) -> BoxStream<'_, Result<Directory, Error>>
fn get_recursive( &self, root_directory_digest: &B3Digest, ) -> BoxStream<'_, Result<Directory, Error>>
Source§fn put<'life0, 'async_trait>(
&'life0 self,
_directory: Directory,
) -> Pin<Box<dyn Future<Output = Result<B3Digest, Error>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn put<'life0, 'async_trait>(
&'life0 self,
_directory: Directory,
) -> Pin<Box<dyn Future<Output = Result<B3Digest, Error>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Uploads a single Directory message, and returns the calculated
digest, or an error. An error must also be returned if the message is
not valid.
Source§fn put_multiple_start(&self) -> Box<dyn DirectoryPutter + '_>
fn put_multiple_start(&self) -> Box<dyn DirectoryPutter + '_>
Allows persisting a closure of Directory, which is a graph of
connected Directory messages.
Auto Trait Implementations§
impl<DS> Freeze for Priority<DS>
impl<DS> RefUnwindSafe for Priority<DS>where
DS: RefUnwindSafe,
impl<DS> Send for Priority<DS>where
DS: Send,
impl<DS> Sync for Priority<DS>where
DS: Sync,
impl<DS> Unpin for Priority<DS>
impl<DS> UnsafeUnpin for Priority<DS>
impl<DS> UnwindSafe for Priority<DS>where
DS: RefUnwindSafe,
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
Mutably borrows from an owned value. Read more
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>
Converts
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>
Converts
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 more§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::RequestCreates a shared type from an unshared type.
§impl<L> LayerExt<L> for L
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
Applies the layer to a service and wraps it in [
Layered].