pub struct BoxCloneSyncServiceLayer<In, T, U, E> { /* private fields */ }util only.Expand description
A Clone + Send + Sync boxed Layer.
BoxCloneSyncServiceLayer turns a layer into a trait object, allowing both the Layer itself
and the output Service to be dynamic, while having consistent types.
This Layer produces BoxCloneSyncService instances erasing the type of the
Service produced by the wrapped Layer.
This is similar to BoxCloneServiceLayer except the layer and resulting
service implements Sync.
§Example
BoxCloneSyncServiceLayer can, for example, be useful to create layers dynamically that otherwise wouldn’t have
the same types, when the underlying service must be clone and sync (for example, when building a Hyper connector).
In this example, we include a Timeout layer only if an environment variable is set. We can use
BoxCloneSyncServiceLayer to return a consistent type regardless of runtime configuration:
use std::time::Duration;
use tower::{Service, ServiceBuilder, BoxError};
use tower::util::{BoxCloneSyncServiceLayer, BoxCloneSyncService};
fn common_layer<S, T>() -> BoxCloneSyncServiceLayer<S, T, S::Response, BoxError>
where
S: Service<T> + Clone + Send + Sync + 'static,
S::Future: Send + 'static,
S::Error: Into<BoxError> + 'static,
{
let builder = ServiceBuilder::new()
.concurrency_limit(100);
if std::env::var("SET_TIMEOUT").is_ok() {
let layer = builder
.timeout(Duration::from_secs(30))
.into_inner();
BoxCloneSyncServiceLayer::new(layer)
} else {
let layer = builder
.map_err(Into::into)
.into_inner();
BoxCloneSyncServiceLayer::new(layer)
}
}
// We can clone the layer (this is true of BoxLayer as well)
let boxed_clone_sync_layer = common_layer();
let cloned_sync_layer = boxed_clone_sync_layer.clone();
// Using the `BoxCloneSyncServiceLayer` we can create a `BoxCloneSyncService`
let service: BoxCloneSyncService<Request, Response, BoxError> = ServiceBuilder::new().layer(cloned_sync_layer)
.service_fn(|req: Request| async {
Ok::<_, BoxError>(Response::new())
});
// And we can still clone the service
let cloned_service = service.clone();
Implementations§
Source§impl<In, T, U, E> BoxCloneSyncServiceLayer<In, T, U, E>
impl<In, T, U, E> BoxCloneSyncServiceLayer<In, T, U, E>
Trait Implementations§
Source§impl<In, T, U, E> Clone for BoxCloneSyncServiceLayer<In, T, U, E>
impl<In, T, U, E> Clone for BoxCloneSyncServiceLayer<In, T, U, E>
Source§impl<In, T, U, E> Debug for BoxCloneSyncServiceLayer<In, T, U, E>
impl<In, T, U, E> Debug for BoxCloneSyncServiceLayer<In, T, U, E>
Source§impl<In, T, U, E> Layer<In> for BoxCloneSyncServiceLayer<In, T, U, E>
impl<In, T, U, E> Layer<In> for BoxCloneSyncServiceLayer<In, T, U, E>
Auto Trait Implementations§
impl<In, T, U, E> Freeze for BoxCloneSyncServiceLayer<In, T, U, E>
impl<In, T, U, E> !RefUnwindSafe for BoxCloneSyncServiceLayer<In, T, U, E>
impl<In, T, U, E> Send for BoxCloneSyncServiceLayer<In, T, U, E>
impl<In, T, U, E> Sync for BoxCloneSyncServiceLayer<In, T, U, E>
impl<In, T, U, E> Unpin for BoxCloneSyncServiceLayer<In, T, U, E>
impl<In, T, U, E> !UnwindSafe for BoxCloneSyncServiceLayer<In, T, U, E>
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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> WithSubscriber for T
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 16 bytes