async-std/examples/socket-timeouts.rs

29 lines
752 B
Rust
Raw Normal View History

2019-09-27 00:57:56 +00:00
//! Prints response of GET request made to TCP server with 5 second socket timeout
2019-08-26 18:08:51 +00:00
use std::time::Duration;
2019-08-26 18:38:11 +00:00
use async_std::{io, net::TcpStream, prelude::*, task};
2019-08-26 18:08:51 +00:00
async fn get() -> io::Result<Vec<u8>> {
let mut stream = TcpStream::connect("example.com:80").await?;
2019-08-26 18:38:11 +00:00
stream
.write_all(b"GET /index.html HTTP/1.0\r\n\r\n")
.await?;
2019-08-26 18:08:51 +00:00
let mut buf = vec![];
io::timeout(Duration::from_secs(5), async move {
2019-08-26 18:08:51 +00:00
stream.read_to_end(&mut buf).await?;
Ok(buf)
2019-08-26 18:38:11 +00:00
})
.await
2019-08-26 18:08:51 +00:00
}
fn main() {
task::block_on(async {
let raw_response = get().await.expect("request");
2019-08-26 18:38:11 +00:00
let response = String::from_utf8(raw_response).expect("utf8 conversion");
2019-08-26 18:08:51 +00:00
println!("received: {}", response);
});
}