1
0
mirror of https://github.com/fafhrd91/actix-net synced 2024-12-18 06:53:11 +01:00
actix-net/examples/ssl.rs

65 lines
1.6 KiB
Rust
Raw Normal View History

2018-08-19 19:47:04 +02:00
extern crate actix;
extern crate actix_net;
extern crate futures;
extern crate openssl;
extern crate tokio_io;
extern crate tokio_tcp;
use std::io;
use std::sync::{
atomic::{AtomicUsize, Ordering},
Arc,
};
use futures::{future, Future};
use openssl::ssl::{SslAcceptor, SslFiletype, SslMethod};
use tokio_io::{AsyncRead, AsyncWrite};
2018-08-24 00:42:34 +02:00
use actix_net::{ssl, NewServiceExt, Server};
2018-08-19 19:47:04 +02:00
#[derive(Debug)]
struct ServiceState {
num: Arc<AtomicUsize>,
}
fn service<T: AsyncRead + AsyncWrite>(
2018-08-22 02:08:23 +02:00
st: &mut ServiceState, _: T,
2018-08-19 19:47:04 +02:00
) -> impl Future<Item = (), Error = io::Error> {
let num = st.num.fetch_add(1, Ordering::Relaxed);
println!("got ssl connection {:?}", num);
future::ok(())
}
fn main() {
let sys = actix::System::new("test");
// load ssl keys
let mut builder = SslAcceptor::mozilla_intermediate(SslMethod::tls()).unwrap();
builder
.set_private_key_file("./examples/key.pem", SslFiletype::PEM)
.unwrap();
builder
.set_certificate_chain_file("./examples/cert.pem")
.unwrap();
let num = Arc::new(AtomicUsize::new(0));
let openssl = ssl::OpensslAcceptor::new(builder);
2018-08-19 19:47:04 +02:00
2018-08-23 22:39:13 +02:00
// server start mutiple workers, it runs supplied `Fn` in each worker.
2018-08-24 00:42:34 +02:00
Server::default()
.bind("0.0.0.0:8443", move || {
let num = num.clone();
// configure service
openssl
.clone()
.map_err(|e| io::Error::new(io::ErrorKind::Other, e))
.and_then((service, move || {
Ok::<_, io::Error>(ServiceState { num: num.clone() })
}))
2018-08-24 00:42:34 +02:00
}).unwrap()
.start();
2018-08-19 19:47:04 +02:00
sys.run();
}