From 30643d5648a8c5673ffdebcc6a9617284b173a2c Mon Sep 17 00:00:00 2001 From: ibraheemdev Date: Fri, 25 Dec 2020 15:57:29 -0500 Subject: [PATCH] simplify handler trait --- src/handler.rs | 80 ++++++++++++++++++++++++------------------------- src/resource.rs | 8 ++--- src/route.rs | 8 ++--- src/web.rs | 8 ++--- 4 files changed, 52 insertions(+), 52 deletions(-) diff --git a/src/handler.rs b/src/handler.rs index 4c86db114..b928939a5 100644 --- a/src/handler.rs +++ b/src/handler.rs @@ -20,19 +20,19 @@ use crate::service::{ServiceRequest, ServiceResponse}; /// /// If you got the error `the trait Handler<_, _, _> is not implemented`, then your function is not /// a valid handler. See [Request Handlers](https://actix.rs/docs/handlers/) for more information. -pub trait Handler: Clone + 'static +pub trait Handler: Clone + 'static where - R: Future, - O: Responder, + R: Future, + R::Output: Responder, { fn call(&self, param: T) -> R; } -impl Handler<(), R, O> for F +impl Handler<(), R> for F where F: Fn() -> R + Clone + 'static, - R: Future, - O: Responder, + R: Future, + R::Output: Responder, { fn call(&self, _: ()) -> R { (self)() @@ -41,23 +41,23 @@ where #[doc(hidden)] /// Extract arguments from request, run factory function and make response. -pub struct HandlerService +pub struct HandlerService where - F: Handler, + F: Handler, T: FromRequest, - R: Future, - O: Responder, + R: Future, + R::Output: Responder, { hnd: F, - _t: PhantomData<(T, R, O)>, + _t: PhantomData<(T, R)>, } -impl HandlerService +impl HandlerService where - F: Handler, + F: Handler, T: FromRequest, - R: Future, - O: Responder, + R: Future, + R::Output: Responder, { pub fn new(hnd: F) -> Self { Self { @@ -67,12 +67,12 @@ where } } -impl Clone for HandlerService +impl Clone for HandlerService where - F: Handler, + F: Handler, T: FromRequest, - R: Future, - O: Responder, + R: Future, + R::Output: Responder, { fn clone(&self) -> Self { Self { @@ -82,12 +82,12 @@ where } } -impl ServiceFactory for HandlerService +impl ServiceFactory for HandlerService where - F: Handler, + F: Handler, T: FromRequest, - R: Future, - O: Responder, + R: Future, + R::Output: Responder, { type Request = ServiceRequest; type Response = ServiceResponse; @@ -103,17 +103,17 @@ where } // Handler is both it's ServiceHandler and Service Type. -impl Service for HandlerService +impl Service for HandlerService where - F: Handler, + F: Handler, T: FromRequest, - R: Future, - O: Responder, + R: Future, + R::Output: Responder, { type Request = ServiceRequest; type Response = ServiceResponse; type Error = Error; - type Future = HandlerServiceFuture; + type Future = HandlerServiceFuture; fn poll_ready(&mut self, _: &mut Context<'_>) -> Poll> { Poll::Ready(Ok(())) @@ -128,24 +128,24 @@ where #[doc(hidden)] #[pin_project(project = HandlerProj)] -pub enum HandlerServiceFuture +pub enum HandlerServiceFuture where - F: Handler, + F: Handler, T: FromRequest, - R: Future, - O: Responder, + R: Future, + R::Output: Responder, { Extract(#[pin] T::Future, Option, F), Handle(#[pin] R, Option), - Respond(#[pin] O::Future, Option), + Respond(#[pin] ::Future, Option), } -impl Future for HandlerServiceFuture +impl Future for HandlerServiceFuture where - F: Handler, + F: Handler, T: FromRequest, - R: Future, - O: Responder, + R: Future, + R::Output: Responder, { // Error type in this future is a placeholder type. // all instances of error must be converted to ServiceResponse and return in Ok. @@ -186,10 +186,10 @@ where /// FromRequest trait impl for tuples macro_rules! factory_tuple ({ $(($n:tt, $T:ident)),+} => { - impl Handler<($($T,)+), Res, O> for Func + impl Handler<($($T,)+), Res> for Func where Func: Fn($($T,)+) -> Res + Clone + 'static, - Res: Future, - O: Responder, + Res: Future, + Res::Output: Responder, { fn call(&self, param: ($($T,)+)) -> Res { (self)($(param.$n,)+) diff --git a/src/resource.rs b/src/resource.rs index 2f9d95571..f6046d652 100644 --- a/src/resource.rs +++ b/src/resource.rs @@ -227,12 +227,12 @@ where /// # fn index(req: HttpRequest) -> HttpResponse { unimplemented!() } /// App::new().service(web::resource("/").route(web::route().to(index))); /// ``` - pub fn to(mut self, handler: F) -> Self + pub fn to(mut self, handler: F) -> Self where - F: Handler, + F: Handler, I: FromRequest + 'static, - R: Future + 'static, - U: Responder + 'static, + R: Future + 'static, + R::Output: Responder + 'static, { self.routes.push(Route::new().to(handler)); self diff --git a/src/route.rs b/src/route.rs index 04451017a..00d93fce9 100644 --- a/src/route.rs +++ b/src/route.rs @@ -219,12 +219,12 @@ impl Route { /// ); /// } /// ``` - pub fn to(mut self, handler: F) -> Self + pub fn to(mut self, handler: F) -> Self where - F: Handler, + F: Handler, T: FromRequest + 'static, - R: Future + 'static, - U: Responder + 'static, + R: Future + 'static, + R::Output: Responder + 'static, { self.service = Box::new(RouteNewService::new(HandlerService::new(handler))); self diff --git a/src/web.rs b/src/web.rs index 463829fc3..85e5f2e7b 100644 --- a/src/web.rs +++ b/src/web.rs @@ -244,12 +244,12 @@ pub fn method(method: Method) -> Route { /// web::to(index)) /// ); /// ``` -pub fn to(handler: F) -> Route +pub fn to(handler: F) -> Route where - F: Handler, + F: Handler, I: FromRequest + 'static, - R: Future + 'static, - U: Responder + 'static, + R: Future + 'static, + R::Output: Responder + 'static, { Route::new().to(handler) }