1
0
mirror of https://github.com/actix/examples synced 2024-11-23 22:41:07 +01:00

Merge pull request #10 from Dowwie/master

added with_async example to async_ex1
This commit is contained in:
Nikolay Kim 2018-05-11 08:51:04 -07:00 committed by GitHub
commit 88194b9cd4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -11,6 +11,10 @@
// 2. actix-web client features: // 2. actix-web client features:
// - POSTing json body // - POSTing json body
// 3. chaining futures into a single response used by an asynch endpoint // 3. chaining futures into a single response used by an asynch endpoint
//
// There are 2 versions in this example, one that uses Boxed Futures and the other that uses Impl
// Future, available since rustc v1.26.
extern crate actix; extern crate actix;
extern crate actix_web; extern crate actix_web;
@ -51,8 +55,13 @@ struct HttpBinResponse {
url: String, url: String,
} }
// -----------------------------------------------------------------------
// v1 uses Boxed Futures, which were the only option prior to rustc v1.26
// -----------------------------------------------------------------------
/// post json to httpbin, get it back in the response body, return deserialized /// post json to httpbin, get it back in the response body, return deserialized
fn step_x(data: SomeData) -> Box<Future<Item = SomeData, Error = Error>> { fn step_x_v1(data: SomeData) -> Box<Future<Item = SomeData, Error = Error>> {
Box::new( Box::new(
client::ClientRequest::post("https://httpbin.org/post") client::ClientRequest::post("https://httpbin.org/post")
.json(data).unwrap() .json(data).unwrap()
@ -70,13 +79,13 @@ fn step_x(data: SomeData) -> Box<Future<Item = SomeData, Error = Error>> {
) )
} }
fn create_something( fn create_something_v1(
some_data: Json<SomeData>, some_data: Json<SomeData>,
) -> Box<Future<Item = HttpResponse, Error = Error>> { ) -> Box<Future<Item = HttpResponse, Error = Error>> {
step_x(some_data.into_inner()) step_x_v1(some_data.into_inner())
.and_then(|some_data_2| { .and_then(|some_data_2| {
step_x(some_data_2).and_then(|some_data_3| { step_x_v1(some_data_2).and_then(|some_data_3| {
step_x(some_data_3).and_then(|d| { step_x_v1(some_data_3).and_then(|d| {
Ok(HttpResponse::Ok() Ok(HttpResponse::Ok()
.content_type("application/json") .content_type("application/json")
.body(serde_json::to_string(&d).unwrap()) .body(serde_json::to_string(&d).unwrap())
@ -87,17 +96,59 @@ fn create_something(
.responder() .responder()
} }
// ---------------------------------------------------------------
// v2 uses impl Future, available as of rustc v1.26
// ---------------------------------------------------------------
/// post json to httpbin, get it back in the response body, return deserialized
fn step_x_v2(data: SomeData) -> impl Future<Item = SomeData, Error = Error> {
client::ClientRequest::post("https://httpbin.org/post")
.json(data).unwrap()
.send()
.conn_timeout(Duration::from_secs(10))
.map_err(Error::from) // <- convert SendRequestError to an Error
.and_then(
|resp| resp.body() // <- this is MessageBody type, resolves to complete body
.from_err() // <- convert PayloadError to a Error
.and_then(|body| {
let resp: HttpBinResponse = serde_json::from_slice(&body).unwrap();
fut_ok(resp.json)
})
)
}
fn create_something_v2(some_data: Json<SomeData>)
-> impl Future<Item = HttpResponse, Error = Error> {
step_x_v2(some_data.into_inner())
.and_then(|some_data_2| {
step_x_v2(some_data_2).and_then(|some_data_3| {
step_x_v2(some_data_3).and_then(|d|
Ok(HttpResponse::Ok()
.content_type("application/json")
.body(serde_json::to_string(&d).unwrap())
.into()))
})
})
}
fn main() { fn main() {
env_logger::init(); env_logger::init();
let sys = actix::System::new("asyncio_example"); let sys = actix::System::new("asyncio_example");
server::new(move || { server::new(move || {
App::new().resource("/something", |r| { App::new()
r.method(Method::POST).with(create_something) .resource("/something_v1", |r| {
r.method(Method::POST).with(create_something_v1)})
.resource("/something_v2", |r| {
r.method(Method::POST).with_async(create_something_v2)})
}) })
}).bind("127.0.0.1:8088") .bind("127.0.0.1:8088")
.unwrap() .unwrap()
.start(); .start();
println!("Started http server: 127.0.0.1:8088"); println!("Started http server: 127.0.0.1:8088");
let _ = sys.run(); let _ = sys.run();