change: update client example

This commit is contained in:
quininer 2018-03-24 01:22:45 +08:00
parent 062c10e31e
commit 8f2306854e

View File

@ -15,18 +15,10 @@ use std::io::{ BufReader, stdout, stdin };
use std::fs; use std::fs;
use tokio::io; use tokio::io;
use tokio::prelude::*; use tokio::prelude::*;
use tokio_core::net::TcpStream;
use tokio_core::reactor::Core;
use clap::{ App, Arg }; use clap::{ App, Arg };
use rustls::ClientConfig; use rustls::ClientConfig;
use tokio_rustls::ClientConfigExt; use tokio_rustls::ClientConfigExt;
#[cfg(unix)]
use tokio::io::AsyncRead;
#[cfg(unix)]
use tokio_file_unix::{ StdFile, File };
#[cfg(not(unix))] #[cfg(not(unix))]
use std::io::{Read, Write}; use std::io::{Read, Write};
@ -44,17 +36,13 @@ fn main() {
let matches = app().get_matches(); let matches = app().get_matches();
let host = matches.value_of("host").unwrap(); let host = matches.value_of("host").unwrap();
let port = if let Some(port) = matches.value_of("port") { let port = matches.value_of("port")
port.parse().unwrap() .map(|port| port.parse().unwrap())
} else { .unwrap_or(443);
443
};
let domain = matches.value_of("domain").unwrap_or(host); let domain = matches.value_of("domain").unwrap_or(host);
let cafile = matches.value_of("cafile"); let cafile = matches.value_of("cafile");
let text = format!("GET / HTTP/1.0\r\nHost: {}\r\n\r\n", domain); let text = format!("GET / HTTP/1.0\r\nHost: {}\r\n\r\n", domain);
let mut core = Core::new().unwrap();
let handle = core.handle();
let addr = (host, port) let addr = (host, port)
.to_socket_addrs().unwrap() .to_socket_addrs().unwrap()
.next().unwrap(); .next().unwrap();
@ -67,28 +55,28 @@ fn main() {
config.root_store.add_server_trust_anchors(&webpki_roots::TLS_SERVER_ROOTS); config.root_store.add_server_trust_anchors(&webpki_roots::TLS_SERVER_ROOTS);
} }
let arc_config = Arc::new(config); let arc_config = Arc::new(config);
let domain = webpki::DNSNameRef::try_from_ascii_str(domain).unwrap(); let domain = webpki::DNSNameRef::try_from_ascii_str(domain).unwrap();
// Use async non-blocking I/O for stdin/stdout on Unixy platforms.
#[cfg(unix)]
{
use tokio::io::AsyncRead;
use tokio_core::reactor::Core;
use tokio_core::net::TcpStream;
use tokio_file_unix::{ StdFile, File };
let mut core = Core::new().unwrap();
let handle = core.handle();
let socket = TcpStream::connect(&addr, &handle); let socket = TcpStream::connect(&addr, &handle);
// Use async non-blocking I/O for stdin/stdout on Unixy platforms.
#[cfg(unix)]
let stdin = stdin(); let stdin = stdin();
#[cfg(unix)]
let stdin = File::new_nb(StdFile(stdin.lock())).unwrap() let stdin = File::new_nb(StdFile(stdin.lock())).unwrap()
.into_io(&handle).unwrap(); .into_io(&handle).unwrap();
#[cfg(unix)]
let stdout = stdout(); let stdout = stdout();
#[cfg(unix)]
let stdout = File::new_nb(StdFile(stdout.lock())).unwrap() let stdout = File::new_nb(StdFile(stdout.lock())).unwrap()
.into_io(&handle).unwrap(); .into_io(&handle).unwrap();
#[cfg(unix)]
let resp = socket let resp = socket
.and_then(|stream| arc_config.connect_async(domain, stream)) .and_then(|stream| arc_config.connect_async(domain, stream))
.and_then(|stream| io::write_all(stream, text.as_bytes())) .and_then(|stream| io::write_all(stream, text.as_bytes()))
@ -100,16 +88,20 @@ fn main() {
.map_err(|(e, _)| e) .map_err(|(e, _)| e)
}); });
core.run(resp).unwrap();
}
// XXX: For now, just use blocking I/O for stdin/stdout on other platforms. // XXX: For now, just use blocking I/O for stdin/stdout on other platforms.
// The network I/O will still be asynchronous and non-blocking. // The network I/O will still be asynchronous and non-blocking.
#[cfg(not(unix))] #[cfg(not(unix))]
{
use tokio::net::TcpStream;
let socket = TcpStream::connect(&addr);
let mut input = Vec::new(); let mut input = Vec::new();
#[cfg(not(unix))]
stdin().read_to_end(&mut input).unwrap(); stdin().read_to_end(&mut input).unwrap();
#[cfg(not(unix))]
let resp = socket let resp = socket
.and_then(|stream| arc_config.connect_async(domain, stream)) .and_then(|stream| arc_config.connect_async(domain, stream))
.and_then(|stream| io::write_all(stream, text.as_bytes())) .and_then(|stream| io::write_all(stream, text.as_bytes()))
@ -117,5 +109,6 @@ fn main() {
.and_then(|(stream, _)| io::read_to_end(stream, Vec::new())) .and_then(|(stream, _)| io::read_to_end(stream, Vec::new()))
.and_then(|(_, output)| stdout().write_all(&output)); .and_then(|(_, output)| stdout().write_all(&output));
core.run(resp).unwrap(); resp.wait().unwrap();
}
} }