From 9b012b33047999294627180c6744da41714b9408 Mon Sep 17 00:00:00 2001 From: Nikolay Kim Date: Mon, 11 Jun 2018 19:44:11 -0700 Subject: [PATCH] do not allow stream or actor responses for internal error #301 --- src/error.rs | 17 +++++++++++++++-- src/httpresponse.rs | 2 +- 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/src/error.rs b/src/error.rs index 9a0195684..f3327c2b6 100644 --- a/src/error.rs +++ b/src/error.rs @@ -3,7 +3,7 @@ use std::io::Error as IoError; use std::str::Utf8Error; use std::string::FromUtf8Error; use std::sync::Mutex; -use std::{fmt, io, result}; +use std::{fmt, io, mem, result}; use actix::MailboxError; use cookie; @@ -22,6 +22,7 @@ pub use url::ParseError as UrlParseError; // re-exports pub use cookie::ParseError as CookieParseError; +use body::Body; use handler::Responder; use httprequest::HttpRequest; use httpresponse::{HttpResponse, InnerHttpResponse}; @@ -673,9 +674,21 @@ impl InternalError { /// Create `InternalError` with predefined `HttpResponse`. pub fn from_response(cause: T, response: HttpResponse) -> Self { + let mut resp = response.into_inner(); + let body = mem::replace(&mut resp.body, Body::Empty); + match body { + Body::Empty => (), + Body::Binary(mut bin) => { + resp.body = Body::Binary(bin.take().into()); + } + Body::Streaming(_) | Body::Actor(_) => { + error!("Streaming or Actor body is not support by error response"); + } + } + InternalError { cause, - status: InternalErrorType::Response(Mutex::new(Some(response.into_inner()))), + status: InternalErrorType::Response(Mutex::new(Some(resp))), backtrace: Backtrace::new(), } } diff --git a/src/httpresponse.rs b/src/httpresponse.rs index 1a62232b1..f42be2b9f 100644 --- a/src/httpresponse.rs +++ b/src/httpresponse.rs @@ -810,7 +810,7 @@ pub(crate) struct InnerHttpResponse { headers: HeaderMap, status: StatusCode, reason: Option<&'static str>, - body: Body, + pub(crate) body: Body, chunked: Option, encoding: Option, connection_type: Option,