RouteBuilder

Struct RouteBuilder 

Source
pub struct RouteBuilder<'a> { /* private fields */ }
Expand description

Add a new API route by providing a description (optional but encouraged) and then a handler function.

§Examples

// This route expects a JSON formatted string to be provided, and echoes it straight back.
api.add("echo")
   .description("Echo back the JSON encoded string provided")
   .handler(|body: FromJson<String>| ToJson(body.0));

// This route delegates to an async fn to sum some values, so we can infer more types in the handler.
api.add("another.route")
   .description("This route takes an array of values and sums them")
   .handler(|FromJson(body)| sum(body));

async fn sum(ns: Vec<u64>) -> Result<ToJson<u64>, Infallible> {
    Ok(ToJson(ns.into_iter().sum()))
}

Implementations§

Source§

impl<'a> RouteBuilder<'a>

Source

pub fn description<S: Into<String>>(self, desc: S) -> Self

Add a description to the API route.

Source

pub fn handler<A, HandlerFn: IntoHandler<A>>(self, handler: HandlerFn)

Add a handler to the API route. Until this has been added, the route doesn’t “exist”.

Auto Trait Implementations§

§

impl<'a> Freeze for RouteBuilder<'a>

§

impl<'a> !RefUnwindSafe for RouteBuilder<'a>

§

impl<'a> Send for RouteBuilder<'a>

§

impl<'a> Sync for RouteBuilder<'a>

§

impl<'a> Unpin for RouteBuilder<'a>

§

impl<'a> !UnwindSafe for RouteBuilder<'a>

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