1
0
Fork 0
mirror of https://github.com/actix/actix-web.git synced 2024-06-02 13:29:24 +00:00
actix-web/actix-multipart/src/extractor.rs

44 lines
1.3 KiB
Rust
Raw Normal View History

//! Multipart payload support
2021-04-01 14:26:13 +00:00
use actix_utils::future::{ready, Ready};
use actix_web::{dev::Payload, Error, FromRequest, HttpRequest};
use crate::server::Multipart;
2021-04-01 14:26:13 +00:00
/// Get request's payload as multipart stream.
///
/// Content-type: multipart/form-data;
///
/// # Examples
/// ```
/// use actix_web::{web, HttpResponse, Error};
2021-04-01 14:26:13 +00:00
/// use actix_multipart::Multipart;
/// use futures_util::StreamExt as _;
///
2021-04-01 14:26:13 +00:00
/// async fn index(mut payload: Multipart) -> Result<HttpResponse, Error> {
2019-11-21 08:25:50 +00:00
/// // iterate over multipart stream
/// while let Some(item) = payload.next().await {
/// let mut field = item?;
///
2019-04-13 17:11:07 +00:00
/// // Field in turn is stream of *Bytes* object
2019-11-21 08:25:50 +00:00
/// while let Some(chunk) = field.next().await {
/// println!("-- CHUNK: \n{:?}", std::str::from_utf8(&chunk?));
/// }
/// }
2021-04-01 14:26:13 +00:00
///
2019-11-21 08:25:50 +00:00
/// Ok(HttpResponse::Ok().into())
/// }
/// ```
impl FromRequest for Multipart {
type Error = Error;
2019-11-21 08:25:50 +00:00
type Future = Ready<Result<Multipart, Error>>;
#[inline]
fn from_request(req: &HttpRequest, payload: &mut Payload) -> Self::Future {
2021-04-01 14:26:13 +00:00
ready(Ok(match Multipart::boundary(req.headers()) {
Ok(boundary) => Multipart::from_boundary(boundary, payload.take()),
Err(err) => Multipart::from_error(err),
2021-04-01 14:26:13 +00:00
}))
}
}