hyper-sync-rustls
This is an integration between the rustls
TLS
stack and the synchronous version (0.10) of the
hyper
HTTP library. This is a maintained
fork of hyper_sync_rustls
for synchronous
hyper.
These are provided as an example of the minimal changes needed to use rustls in your existing hyper-based program. Note that these are derived works of original hyper source, and are distributed under hyper's license.
Enable the client
feature for access to client types.
```diff --- ../hyper/examples/client.rs 2016-10-03 23:29:00.850098245 +0100 +++ examples/client.rs 2016-10-08 07:36:05.076449122 +0100 @@ -1,6 +1,8 @@ #![deny(warnings)] extern crate hyper;
+extern crate hypersyncrustls; + extern crate env_logger;
use std::env; @@ -8,6 +10,7 @@
use hyper::Client; use hyper::header::Connection; +use hyper::net::HttpsConnector;
fn main() { envlogger::init().unwrap(); @@ -32,7 +35,7 @@ } Client::withhttpproxy(proxy, port) }, - _ => Client::new() + _ => Client::withconnector(HttpsConnector::new(hypersyncrustls::TlsClient::new())) };
let mut res = client.get(&*url)
```
Enable the server
feature for access to client types.
```diff --- ../hyper/examples/server.rs 2016-10-03 23:29:00.850098245 +0100 +++ examples/server.rs 2016-10-08 07:31:38.720667338 +0100 @@ -1,5 +1,6 @@ #![deny(warnings)] extern crate hyper; +extern crate hypersyncrustls; extern crate env_logger;
use std::io::copy; @@ -41,7 +42,10 @@
fn main() { envlogger::init().unwrap(); - let server = Server::http("127.0.0.1:1337").unwrap(); + let certs = hypersyncrustls::util::loadcerts("examples/sample.pem").unwrap(); + let key = hypersyncrustls::util::loadprivatekey("examples/sample.rsa").unwrap(); + let tls = hypersyncrustls::TlsServer::new(certs, key); + let server = Server::https("127.0.0.1:1337", tls).unwrap(); let _guard = server.handle(echo); - println!("Listening on http://127.0.0.1:1337"); + println!("Listening on https://127.0.0.1:1337"); } ```
hyper-sync-rustls
is licensed under either of the following, at your option: