Read body in the example server (#544)
Co-authored-by: Kornel Lesiński <kornel@cloudflare.com>
This commit is contained in:
@@ -1,7 +1,9 @@
|
|||||||
use std::error::Error;
|
use std::error::Error;
|
||||||
|
|
||||||
use bytes::Bytes;
|
use bytes::Bytes;
|
||||||
use h2::server;
|
use h2::server::{self, SendResponse};
|
||||||
|
use h2::RecvStream;
|
||||||
|
use http::Request;
|
||||||
use tokio::net::{TcpListener, TcpStream};
|
use tokio::net::{TcpListener, TcpStream};
|
||||||
|
|
||||||
#[tokio::main]
|
#[tokio::main]
|
||||||
@@ -15,7 +17,7 @@ async fn main() -> Result<(), Box<dyn Error + Send + Sync>> {
|
|||||||
loop {
|
loop {
|
||||||
if let Ok((socket, _peer_addr)) = listener.accept().await {
|
if let Ok((socket, _peer_addr)) = listener.accept().await {
|
||||||
tokio::spawn(async move {
|
tokio::spawn(async move {
|
||||||
if let Err(e) = handle(socket).await {
|
if let Err(e) = serve(socket).await {
|
||||||
println!(" -> err={:?}", e);
|
println!(" -> err={:?}", e);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@@ -23,22 +25,41 @@ async fn main() -> Result<(), Box<dyn Error + Send + Sync>> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn handle(socket: TcpStream) -> Result<(), Box<dyn Error + Send + Sync>> {
|
async fn serve(socket: TcpStream) -> Result<(), Box<dyn Error + Send + Sync>> {
|
||||||
let mut connection = server::handshake(socket).await?;
|
let mut connection = server::handshake(socket).await?;
|
||||||
println!("H2 connection bound");
|
println!("H2 connection bound");
|
||||||
|
|
||||||
while let Some(result) = connection.accept().await {
|
while let Some(result) = connection.accept().await {
|
||||||
let (request, mut respond) = result?;
|
let (request, respond) = result?;
|
||||||
println!("GOT request: {:?}", request);
|
tokio::spawn(async move {
|
||||||
let response = http::Response::new(());
|
if let Err(e) = handle_request(request, respond).await {
|
||||||
|
println!("error while handling request: {}", e);
|
||||||
let mut send = respond.send_response(response, false)?;
|
}
|
||||||
|
});
|
||||||
println!(">>>> sending data");
|
|
||||||
send.send_data(Bytes::from_static(b"hello world"), true)?;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
println!("~~~~~~~~~~~~~~~~~~~~~~~~~~~ H2 connection CLOSE !!!!!! ~~~~~~~~~~~");
|
println!("~~~~~~~~~~~ H2 connection CLOSE !!!!!! ~~~~~~~~~~~");
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn handle_request(
|
||||||
|
mut request: Request<RecvStream>,
|
||||||
|
mut respond: SendResponse<Bytes>,
|
||||||
|
) -> Result<(), Box<dyn Error + Send + Sync>> {
|
||||||
|
println!("GOT request: {:?}", request);
|
||||||
|
|
||||||
|
let body = request.body_mut();
|
||||||
|
while let Some(data) = body.data().await {
|
||||||
|
let data = data?;
|
||||||
|
println!("<<<< recv {:?}", data);
|
||||||
|
let _ = body.flow_control().release_capacity(data.len());
|
||||||
|
}
|
||||||
|
|
||||||
|
let response = http::Response::new(());
|
||||||
|
let mut send = respond.send_response(response, false)?;
|
||||||
|
println!(">>>> send");
|
||||||
|
send.send_data(Bytes::from_static(b"hello "), false)?;
|
||||||
|
send.send_data(Bytes::from_static(b"world\n"), true)?;
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -182,9 +182,11 @@ pub struct Handshake<T, B: Buf = Bytes> {
|
|||||||
/// # async fn doc<T: AsyncRead + AsyncWrite + Unpin>(my_io: T) {
|
/// # async fn doc<T: AsyncRead + AsyncWrite + Unpin>(my_io: T) {
|
||||||
/// let mut server = server::handshake(my_io).await.unwrap();
|
/// let mut server = server::handshake(my_io).await.unwrap();
|
||||||
/// while let Some(request) = server.accept().await {
|
/// while let Some(request) = server.accept().await {
|
||||||
/// let (request, respond) = request.unwrap();
|
/// tokio::spawn(async move {
|
||||||
/// // Process the request and send the response back to the client
|
/// let (request, respond) = request.unwrap();
|
||||||
/// // using `respond`.
|
/// // Process the request and send the response back to the client
|
||||||
|
/// // using `respond`.
|
||||||
|
/// });
|
||||||
/// }
|
/// }
|
||||||
/// # }
|
/// # }
|
||||||
/// #
|
/// #
|
||||||
|
|||||||
Reference in New Issue
Block a user