1
0
mirror of https://github.com/fafhrd91/actix-web synced 2025-08-25 14:46:04 +02:00

Rename factory to handler (#1852)

This commit is contained in:
Ibraheem Ahmed
2020-12-26 16:46:19 -05:00
committed by GitHub
parent 1032f04ded
commit cbda928a33
6 changed files with 69 additions and 64 deletions

View File

@@ -14,20 +14,25 @@ use crate::request::HttpRequest;
use crate::responder::Responder;
use crate::service::{ServiceRequest, ServiceResponse};
/// Async handler converter factory
pub trait Factory<T, R, O>: Clone + 'static
/// A request handler is an async function that accepts zero or more parameters that can be
/// extracted from a request (ie, [`impl FromRequest`](crate::FromRequest)) and returns a type that can be converted into
/// an [`HttpResponse`](crate::HttpResponse) (ie, [`impl Responder`](crate::Responder)).
///
/// 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<T, R>: Clone + 'static
where
R: Future<Output = O>,
O: Responder,
R: Future,
R::Output: Responder,
{
fn call(&self, param: T) -> R;
}
impl<F, R, O> Factory<(), R, O> for F
impl<F, R> Handler<(), R> for F
where
F: Fn() -> R + Clone + 'static,
R: Future<Output = O>,
O: Responder,
R: Future,
R::Output: Responder,
{
fn call(&self, _: ()) -> R {
(self)()
@@ -36,53 +41,53 @@ where
#[doc(hidden)]
/// Extract arguments from request, run factory function and make response.
pub struct Handler<F, T, R, O>
pub struct HandlerService<F, T, R>
where
F: Factory<T, R, O>,
F: Handler<T, R>,
T: FromRequest,
R: Future<Output = O>,
O: Responder,
R: Future,
R::Output: Responder,
{
hnd: F,
_t: PhantomData<(T, R, O)>,
_t: PhantomData<(T, R)>,
}
impl<F, T, R, O> Handler<F, T, R, O>
impl<F, T, R> HandlerService<F, T, R>
where
F: Factory<T, R, O>,
F: Handler<T, R>,
T: FromRequest,
R: Future<Output = O>,
O: Responder,
R: Future,
R::Output: Responder,
{
pub fn new(hnd: F) -> Self {
Handler {
Self {
hnd,
_t: PhantomData,
}
}
}
impl<F, T, R, O> Clone for Handler<F, T, R, O>
impl<F, T, R> Clone for HandlerService<F, T, R>
where
F: Factory<T, R, O>,
F: Handler<T, R>,
T: FromRequest,
R: Future<Output = O>,
O: Responder,
R: Future,
R::Output: Responder,
{
fn clone(&self) -> Self {
Handler {
Self {
hnd: self.hnd.clone(),
_t: PhantomData,
}
}
}
impl<F, T, R, O> ServiceFactory for Handler<F, T, R, O>
impl<F, T, R> ServiceFactory for HandlerService<F, T, R>
where
F: Factory<T, R, O>,
F: Handler<T, R>,
T: FromRequest,
R: Future<Output = O>,
O: Responder,
R: Future,
R::Output: Responder,
{
type Request = ServiceRequest;
type Response = ServiceResponse;
@@ -97,18 +102,18 @@ where
}
}
// Handler is both it's ServiceFactory and Service Type.
impl<F, T, R, O> Service for Handler<F, T, R, O>
// Handler is both it's ServiceHandler and Service Type.
impl<F, T, R> Service for HandlerService<F, T, R>
where
F: Factory<T, R, O>,
F: Handler<T, R>,
T: FromRequest,
R: Future<Output = O>,
O: Responder,
R: Future,
R::Output: Responder,
{
type Request = ServiceRequest;
type Response = ServiceResponse;
type Error = Error;
type Future = HandlerServiceFuture<F, T, R, O>;
type Future = HandlerServiceFuture<F, T, R>;
fn poll_ready(&mut self, _: &mut Context<'_>) -> Poll<Result<(), Self::Error>> {
Poll::Ready(Ok(()))
@@ -123,24 +128,24 @@ where
#[doc(hidden)]
#[pin_project(project = HandlerProj)]
pub enum HandlerServiceFuture<F, T, R, O>
pub enum HandlerServiceFuture<F, T, R>
where
F: Factory<T, R, O>,
F: Handler<T, R>,
T: FromRequest,
R: Future<Output = O>,
O: Responder,
R: Future,
R::Output: Responder,
{
Extract(#[pin] T::Future, Option<HttpRequest>, F),
Handle(#[pin] R, Option<HttpRequest>),
Respond(#[pin] O::Future, Option<HttpRequest>),
Respond(#[pin] <R::Output as Responder>::Future, Option<HttpRequest>),
}
impl<F, T, R, O> Future for HandlerServiceFuture<F, T, R, O>
impl<F, T, R> Future for HandlerServiceFuture<F, T, R>
where
F: Factory<T, R, O>,
F: Handler<T, R>,
T: FromRequest,
R: Future<Output = O>,
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.
@@ -181,10 +186,10 @@ where
/// FromRequest trait impl for tuples
macro_rules! factory_tuple ({ $(($n:tt, $T:ident)),+} => {
impl<Func, $($T,)+ Res, O> Factory<($($T,)+), Res, O> for Func
impl<Func, $($T,)+ Res> Handler<($($T,)+), Res> for Func
where Func: Fn($($T,)+) -> Res + Clone + 'static,
Res: Future<Output = O>,
O: Responder,
Res: Future,
Res::Output: Responder,
{
fn call(&self, param: ($($T,)+)) -> Res {
(self)($(param.$n,)+)