DynamicService

Struct DynamicService 

Source
pub struct DynamicService<In, Out>(/* private fields */);
Available on crate features dynamic-service only.
Expand description

Type-erased wrapper for Service that hides the concrete type.

Use DynamicService when working with complex service compositions where the concrete type becomes unwieldy, or when storing services of different types in collections.

Type erasure adds some overhead, but it’s typically negligible compared to the actual service work (network calls, database queries, etc.).

§Examples

use layered::{DynamicService, DynamicServiceExt, Execute, Service};

async fn example() {
    // Create a concrete service that doubles an integer and uses a closure.
    let service = Execute::new(|v: i32| async move { v * 2 });

    // Create a type-erased service
    let service: DynamicService<i32, i32> = service.into_dynamic();

    // Use it like any other service
    let result = service.execute(42).await;
    println!("Result: {}", result);
}

Trait Implementations§

Source§

impl<In, Out> Clone for DynamicService<In, Out>

Source§

fn clone(&self) -> Self

Returns a duplicate 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, Out> Debug for DynamicService<In, Out>

Source§

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

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

impl<In: Send, Out: Send> Service<In> for DynamicService<In, Out>

Source§

type Out = Out

The output type returned by this service.
Source§

async fn execute(&self, input: In) -> Self::Out

Processes the input and returns the output. Read more

Auto Trait Implementations§

§

impl<In, Out> Freeze for DynamicService<In, Out>

§

impl<In, Out> !RefUnwindSafe for DynamicService<In, Out>

§

impl<In, Out> Send for DynamicService<In, Out>

§

impl<In, Out> Sync for DynamicService<In, Out>

§

impl<In, Out> Unpin for DynamicService<In, Out>

§

impl<In, Out> !UnwindSafe for DynamicService<In, Out>

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, dest: *mut u8)

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

impl<In, Out, T> DynamicServiceExt<In, Out> for T
where In: Send + 'static, Out: Send + 'static, T: Service<In, Out = Out> + 'static,

Source§

fn into_dynamic(self) -> DynamicService<In, Out>

Available on crate features dynamic-service only.
Converts this service into a type-erased DynamicService.
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.