tower::util

Struct BoxCloneSyncServiceLayer

Source
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();

Implementations§

Source§

impl<In, T, U, E> BoxCloneSyncServiceLayer<In, T, U, E>

Source

pub fn new<L>(inner_layer: L) -> Self
where L: Layer<In> + Send + Sync + 'static, L::Service: Service<T, Response = U, Error = E> + Send + Sync + Clone + 'static, <L::Service as Service<T>>::Future: Send + 'static,

Trait Implementations§

Source§

impl<In, T, U, E> Clone for BoxCloneSyncServiceLayer<In, T, U, E>

Source§

fn clone(&self) -> Self

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<In, T, U, E> Debug for BoxCloneSyncServiceLayer<In, T, U, E>

Source§

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

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

impl<In, T, U, E> Layer<In> for BoxCloneSyncServiceLayer<In, T, U, E>

Source§

type Service = BoxCloneSyncService<T, U, E>

The wrapped service
Source§

fn layer(&self, inner: In) -> Self::Service

Wrap the given service with the middleware, returning a new service that has been decorated with the middleware.

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> 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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> ToOwned for T
where T: Clone,

Source§

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

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.