From 50891986bc60e02519f3229615954c80d7ed78ba Mon Sep 17 00:00:00 2001 From: Nikolay Kim Date: Wed, 20 Dec 2017 16:05:07 -0800 Subject: [PATCH] simplify json example --- examples/json/src/main.rs | 27 +++++++++++++-------------- guide/src/qs_7.md | 24 ++++++++++++++---------- 2 files changed, 27 insertions(+), 24 deletions(-) diff --git a/examples/json/src/main.rs b/examples/json/src/main.rs index 239874525..1695c4d7a 100644 --- a/examples/json/src/main.rs +++ b/examples/json/src/main.rs @@ -1,17 +1,15 @@ extern crate actix; extern crate actix_web; -extern crate bytes; extern crate futures; extern crate env_logger; extern crate serde_json; #[macro_use] extern crate serde_derive; use actix_web::*; -use bytes::BytesMut; use futures::Stream; use futures::future::{Future, ok, err}; -#[derive(Debug, Deserialize)] +#[derive(Debug, Serialize, Deserialize)] struct MyObj { name: String, number: i32, @@ -24,22 +22,23 @@ fn index(mut req: HttpRequest) -> Result(body) - }) - .map_err(|e| Error::from(e)) + // `concat2` will asynchronously read each chunk of the request body and + // return a single, concatenated, chunk + req.payload_mut().readany().concat2() + // `Future::from_err` acts like `?` in that it coerces the error type from + // the future into the final error type + .from_err() + // `Future::and_then` can be used to merge an asynchronous workflow with a + // synchronous workflow .and_then(|body| { // <- body is loaded, now we can deserialize json match serde_json::from_slice::(&body) { Ok(obj) => { println!("model: {:?}", obj); // <- do something with payload - ok(httpcodes::HTTPOk.response()) // <- send response + ok(httpcodes::HTTPOk.build() // <- send response + .content_type("application/json") + .json(obj).unwrap()) }, - Err(e) => { - err(error::ErrorBadRequest(e).into()) - } + Err(e) => err(error::ErrorBadRequest(e).into()) } }))) } diff --git a/guide/src/qs_7.md b/guide/src/qs_7.md index 2cbc527b6..f821e5e54 100644 --- a/guide/src/qs_7.md +++ b/guide/src/qs_7.md @@ -77,16 +77,20 @@ We need to load request body first and then deserialize json into object. ```rust,ignore fn index(mut req: HttpRequest) -> Future { - req.payload_mut().readany() - .fold(BytesMut::new(), |mut body, chunk| { // <- load request body - body.extend(chunk); - ok(body) - }) - .and_then(|body| { // <- body is loaded, now we can deserialize json - let obj = serde_json::from_slice::(&body).unwrap(); - println!("MODEL: {:?}", obj); // <- do something with payload - ok(httpcodes::HTTPOk.response()) // <- send response - }) + // `concat2` will asynchronously read each chunk of the request body and + // return a single, concatenated, chunk + req.payload_mut().readany().concat2() + // `Future::from_err` acts like `?` in that it coerces the error type from + // the future into the final error type + .from_err() + // `Future::and_then` can be used to merge an asynchronous workflow with a + // synchronous workflow + .and_then(|body| { // <- body is loaded, now we can deserialize json + let obj = serde_json::from_slice::(&body).unwrap(); + ok(httpcodes::HTTPOk.build() // <- send response + .content_type("application/json") + .json(obj).unwrap()) + }) } ```