This crate allows the creation of client/server multipart streams for use with std futures.
With clients, you want to create a MultipartRequest
& add in your fields & files.
Here is an example of how to use the client with hyper:
```rust use anyhow::Error;
use hyper::{header::CONTENTTYPE, Body, Client, Request}; use hyper::{service::makeservicefn, service::servicefn, Response, Server}; use mpart_async::MultipartRequest;
async fn main() -> Result<(), Error> { //Setup a mock server to accept connections. setup_server();
let client = Client::new();
let mut mpart = MultipartRequest::default();
mpart.add_field("foo", "bar");
mpart.add_file("test", "Cargo.toml");
let request = Request::post("http://localhost:3000")
.header(
CONTENT_TYPE,
format!("multipart/form-data; boundary={}", mpart.get_boundary()),
)
.body(Body::wrap_stream(mpart))?;
client.request(request).await?;
Ok(())
}
fn setupserver() { let addr = ([127, 0, 0, 1], 3000).into(); let makesvc = makeservicefn(|conn| async { Ok::<_, Error>(servicefn(mock)) }); let server = Server::bind(&addr).serve(make_svc);
tokio::spawn(server);
}
async fn mock(_: Request
) -> ResultHere is an example of using it with the warp server:
```rust use warp::Filter;
use bytes::Buf; use futures::stream::TryStreamExt; use futures::Stream; use mime::Mime; use mpart_async::MpartStream; use std::convert::Infallible;
async fn main() {
// Match any request and return hello world!
let routes = warp::any()
.and(warp::header::
warp::serve(routes).run(([127, 0, 0, 1], 3030)).await;
}
async fn mpart(
mime: Mime,
body: impl Stream
let mut stream = MpartStream::new(boundary, body.map_ok(|mut buf| buf.to_bytes()));
while let Ok(Some(mut field)) = stream.try_next().await {
println!("Field received:{}", field.name().unwrap());
if let Ok(filename) = field.filename() {
println!("Field filename:{}", filename);
}
while let Ok(Some(bytes)) = field.try_next().await {
println!("Bytes received:{}", bytes.len());
}
}
Ok(format!("Thanks!\n"))
} ```