Enum actix_web::Either[][src]

pub enum Either<A, B> {
    A(A),
    B(B),
}
[]

Combines two different responder types into a single type

use actix_web::{AsyncResponder, Either, Error, HttpRequest, HttpResponse};
use futures::future::result;

type RegisterResult =
    Either<HttpResponse, Box<Future<Item = HttpResponse, Error = Error>>>;

fn index(req: HttpRequest) -> RegisterResult {
    if is_a_variant() {
        // <- choose variant A
        Either::A(HttpResponse::BadRequest().body("Bad data"))
    } else {
        Either::B(
            // <- variant B
            result(Ok(HttpResponse::Ok()
                .content_type("text/html")
                .body("Hello!")))
                .responder(),
        )
    }
}

Variants

[]

First branch of the type

[]

Second branch of the type

Trait Implementations

impl<A: Debug, B: Debug> Debug for Either<A, B>
[src]
[+]

[]

Formats the value using the given formatter. Read more

impl<A, B> Responder for Either<A, B> where
    A: Responder,
    B: Responder
[src]
[+]

The associated item which can be returned.

The associated error which can be returned.

[]

Convert itself to AsyncResult or Error.

impl<A, B, I, E> Future for Either<A, B> where
    A: Future<Item = I, Error = E>,
    B: Future<Item = I, Error = E>, 
[src]
[+]

The type of value that this future will resolved with if it is successful. Read more

The type of error that this future will resolve with if it fails in a normal fashion. Read more

[]

Query this future to see if its value has become available, registering interest if it is not. Read more

[]

Block the current thread until this future is resolved. Read more

[]

Map this future's result to a different type, returning a new future of the resulting type. Read more

[]

Map this future's error to a different error, returning a new future. Read more

[]

Map this future's error to any error implementing From for this future's Error, returning a new future. Read more

[]

Chain on a computation for when a future finished, passing the result of the future to the provided closure f. Read more

[]

Execute another future after this one has resolved successfully. Read more

[]

Execute another future if this one resolves with an error. Read more

[]

Waits for either one of two futures to complete. Read more

[]

Waits for either one of two differently-typed futures to complete. Read more

[]

Joins the result of two futures, waiting for them both to complete. Read more

[]

Same as join, but with more futures.

[]

Same as join, but with more futures.

[]

Same as join, but with more futures.

[]

Convert this future into a single element stream. Read more

[]

Flatten the execution of this future when the successful result of this future is itself another future. Read more

[]

Flatten the execution of this future when the successful result of this future is a stream. Read more

[]

Fuse a future such that poll will never again be called once it has completed. Read more

[]

Do something with the item of a future, passing it on. Read more

[]

Catches unwinding panics while polling the future. Read more

[]

Create a cloneable handle to this future where all handles will resolve to the same result. Read more

Auto Trait Implementations

impl<A, B> Send for Either<A, B> where
    A: Send,
    B: Send

impl<A, B> Sync for Either<A, B> where
    A: Sync,
    B: Sync