pub struct BoxCloneSyncServiceLayer<In, T, U, E> { /* private fields */ }
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();