Skip to content

Commit e7eda0e

Browse files
Add low level OpenSSL example (#1828)
Co-authored-by: David Pedersen <[email protected]>
1 parent 2c1dde7 commit e7eda0e

File tree

4 files changed

+154
-0
lines changed

4 files changed

+154
-0
lines changed

examples/low-level-openssl/Cargo.toml

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
[package]
2+
name = "example-low-level-openssl"
3+
version = "0.1.0"
4+
edition = "2021"
5+
publish = false
6+
7+
[dependencies]
8+
axum = { path = "../../axum" }
9+
futures-util = "0.3"
10+
hyper = { version = "0.14", features = ["full"] }
11+
openssl = "0.10"
12+
tokio = { version = "1", features = ["full"] }
13+
tokio-openssl = "0.6"
14+
tower = { version = "0.4", features = ["make"] }
15+
tracing = "0.1"
16+
tracing-subscriber = { version = "0.3", features = ["env-filter"] }
Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
-----BEGIN CERTIFICATE-----
2+
MIIDkzCCAnugAwIBAgIUXVYkRCrM/ge03DVymDtXCuybp7gwDQYJKoZIhvcNAQEL
3+
BQAwWTELMAkGA1UEBhMCVVMxEzARBgNVBAgMClNvbWUtU3RhdGUxITAfBgNVBAoM
4+
GEludGVybmV0IFdpZGdpdHMgUHR5IEx0ZDESMBAGA1UEAwwJbG9jYWxob3N0MB4X
5+
DTIxMDczMTE0MjIxMloXDTIyMDczMTE0MjIxMlowWTELMAkGA1UEBhMCVVMxEzAR
6+
BgNVBAgMClNvbWUtU3RhdGUxITAfBgNVBAoMGEludGVybmV0IFdpZGdpdHMgUHR5
7+
IEx0ZDESMBAGA1UEAwwJbG9jYWxob3N0MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A
8+
MIIBCgKCAQEA02V5ZjmqLB/VQwTarrz/35qsa83L+DbAoa0001+jVmmC+G9Nufi0
9+
daroFWj/Uicv2fZWETU8JoZKUrX4BK9og5cg5rln/CtBRWCUYIwRgY9R/CdBGPn4
10+
kp+XkSJaCw74ZIyLy/Zfux6h8ES1m9YRnBza+s7U+ImRBRf4MRPtXQ3/mqJxAZYq
11+
dOnKnvssRyD2qutgVTAxwMUvJWIivRhRYDj7WOpS4CEEeQxP1iH1/T5P7FdtTGdT
12+
bVBABCA8JhL96uFGPpOYHcM/7R5EIA3yZ5FNg931QzoDITjtXGtQ6y9/l/IYkWm6
13+
J67RWcN0IoTsZhz0WNU4gAeslVtJLofn8QIDAQABo1MwUTAdBgNVHQ4EFgQUzFnK
14+
NfS4LAYuKeWwHbzooER0yZ0wHwYDVR0jBBgwFoAUzFnKNfS4LAYuKeWwHbzooER0
15+
yZ0wDwYDVR0TAQH/BAUwAwEB/zANBgkqhkiG9w0BAQsFAAOCAQEAk4O+e9jia59W
16+
ZwetN4GU7OWcYhmOgSizRSs6u7mTfp62LDMt96WKU3THksOnZ44HnqWQxsSfdFVU
17+
XJD12tjvVU8Z4FWzQajcHeemUYiDze8EAh6TnxnUcOrU8IcwiKGxCWRY/908jnWg
18+
+MMscfMCMYTRdeTPqD8fGzAlUCtmyzH6KLE3s4Oo/r5+NR+Uvrwpdvb7xe0MwwO9
19+
Q/zR4N8ep/HwHVEObcaBofE1ssZLksX7ZgCP9wMgXRWpNAtC5EWxMbxYjBfWFH24
20+
fDJlBMiGJWg8HHcxK7wQhFh+fuyNzE+xEWPsI9VL1zDftd9x8/QsOagyEOnY8Vxr
21+
AopvZ09uEQ==
22+
-----END CERTIFICATE-----
Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
-----BEGIN PRIVATE KEY-----
2+
MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQDTZXlmOaosH9VD
3+
BNquvP/fmqxrzcv4NsChrTTTX6NWaYL4b025+LR1qugVaP9SJy/Z9lYRNTwmhkpS
4+
tfgEr2iDlyDmuWf8K0FFYJRgjBGBj1H8J0EY+fiSn5eRIloLDvhkjIvL9l+7HqHw
5+
RLWb1hGcHNr6ztT4iZEFF/gxE+1dDf+aonEBlip06cqe+yxHIPaq62BVMDHAxS8l
6+
YiK9GFFgOPtY6lLgIQR5DE/WIfX9Pk/sV21MZ1NtUEAEIDwmEv3q4UY+k5gdwz/t
7+
HkQgDfJnkU2D3fVDOgMhOO1ca1DrL3+X8hiRabonrtFZw3QihOxmHPRY1TiAB6yV
8+
W0kuh+fxAgMBAAECggEADltu8k1qTFLhJgsXWxTFAAe+PBgfCT2WuaRM2So+qqjB
9+
12Of0MieYPt5hbK63HaC3nfHgqWt7yPhulpXfOH45C8IcgMXl93MMg0MJr58leMI
10+
+2ojFrIrerHSFm5R1TxwDEwrVm/mMowzDWFtQCc6zPJ8wNn5RuP48HKfTZ3/2fjw
11+
zEjSwPO2wFMfo1EJNTjlI303lFbdFBs67NaX6puh30M7Tn+gznHKyO5a7F57wkIt
12+
fkgnEy/sgMedQlwX7bRpUoD6f0fZzV8Qz4cHFywtYErczZJh3VGitJoO/VCIDdty
13+
RPXOAqVDd7EpP1UUehZlKVWZ0OZMEfRgKbRCel5abQKBgQDwgwrIQ5+BiZv6a0VT
14+
ETeXB+hRbvBinRykNo/RvLc3j1enRh9/zO/ShadZIXgOAiM1Jnr5Gp8KkNGca6K1
15+
myhtad7xYPODYzNXXp6T1OPgZxHZLIYzVUj6ypXeV64Te5ZiDaJ1D49czsq+PqsQ
16+
XRcgBJSNpFtDFiXWpjXWfx8PxwKBgQDhAnLY5Sl2eeQo+ud0MvjwftB/mN2qCzJY
17+
5AlQpRI4ThWxJgGPuHTR29zVa5iWNYuA5LWrC1y/wx+t5HKUwq+5kxvs+npYpDJD
18+
ZX/w0Glc6s0Jc/mFySkbw9B2LePedL7lRF5OiAyC6D106Sc9V2jlL4IflmOzt4CD
19+
ZTNbLtC6hwKBgHfIzBXxl/9sCcMuqdg1Ovp9dbcZCaATn7ApfHd5BccmHQGyav27
20+
k7XF2xMJGEHhzqcqAxUNrSgV+E9vTBomrHvRvrd5Ec7eGTPqbBA0d0nMC5eeFTh7
21+
wV0miH20LX6Gjt9G6yJiHYSbeV5G1+vOcTYBEft5X/qJjU7aePXbWh0BAoGBAJlV
22+
5tgCCuhvFloK6fHYzqZtdT6O+PfpW20SMXrgkvMF22h2YvgDFrDwqKRUB47NfHzg
23+
3yBpxNH1ccA5/w97QO8w3gX3h6qicpJVOAPusu6cIBACFZfjRv1hyszOZwvw+Soa
24+
Fj5kHkqTY1YpkREPYS9V2dIW1Wjic1SXgZDw7VM/AoGAP/cZ3ZHTSCDTFlItqy5C
25+
rIy2AiY0WJsx+K0qcvtosPOOwtnGjWHb1gdaVdfX/IRkSsX4PAOdnsyidNC5/l/m
26+
y8oa+5WEeGFclWFhr4dnTA766o8HrM2UjIgWWYBF2VKdptGnHxFeJWFUmeQC/xeW
27+
w37pCS7ykL+7gp7V0WShYsw=
28+
-----END PRIVATE KEY-----
Lines changed: 88 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,88 @@
1+
use openssl::ssl::{Ssl, SslAcceptor, SslFiletype, SslMethod};
2+
use tokio_openssl::SslStream;
3+
4+
use axum::{extract::ConnectInfo, routing::get, Router};
5+
use futures_util::future::poll_fn;
6+
use hyper::server::{
7+
accept::Accept,
8+
conn::{AddrIncoming, Http},
9+
};
10+
use std::{net::SocketAddr, path::PathBuf, pin::Pin, sync::Arc};
11+
use tokio::net::TcpListener;
12+
use tower::MakeService;
13+
14+
use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt};
15+
16+
#[tokio::main]
17+
async fn main() {
18+
tracing_subscriber::registry()
19+
.with(
20+
tracing_subscriber::EnvFilter::try_from_default_env()
21+
.unwrap_or_else(|_| "example_low_level_openssl=debug".into()),
22+
)
23+
.with(tracing_subscriber::fmt::layer())
24+
.init();
25+
26+
let mut tls_builder = SslAcceptor::mozilla_modern_v5(SslMethod::tls()).unwrap();
27+
28+
tls_builder
29+
.set_certificate_file(
30+
PathBuf::from(env!("CARGO_MANIFEST_DIR"))
31+
.join("self_signed_certs")
32+
.join("cert.pem"),
33+
SslFiletype::PEM,
34+
)
35+
.unwrap();
36+
37+
tls_builder
38+
.set_private_key_file(
39+
PathBuf::from(env!("CARGO_MANIFEST_DIR"))
40+
.join("self_signed_certs")
41+
.join("key.pem"),
42+
SslFiletype::PEM,
43+
)
44+
.unwrap();
45+
46+
tls_builder.check_private_key().unwrap();
47+
48+
let acceptor = tls_builder.build();
49+
50+
let listener = TcpListener::bind("127.0.0.1:3000").await.unwrap();
51+
let mut listener = AddrIncoming::from_listener(listener).unwrap();
52+
53+
let protocol = Arc::new(Http::new());
54+
55+
let mut app = Router::new()
56+
.route("/", get(handler))
57+
.into_make_service_with_connect_info::<SocketAddr>();
58+
59+
tracing::info!("listening on https://localhost:3000");
60+
61+
loop {
62+
let stream = poll_fn(|cx| Pin::new(&mut listener).poll_accept(cx))
63+
.await
64+
.unwrap()
65+
.unwrap();
66+
67+
let acceptor = acceptor.clone();
68+
69+
let protocol = protocol.clone();
70+
71+
let svc = app.make_service(&stream);
72+
73+
tokio::spawn(async move {
74+
let ssl = Ssl::new(acceptor.context()).unwrap();
75+
let mut tls_stream = SslStream::new(ssl, stream).unwrap();
76+
77+
SslStream::accept(Pin::new(&mut tls_stream)).await.unwrap();
78+
79+
let _ = protocol
80+
.serve_connection(tls_stream, svc.await.unwrap())
81+
.await;
82+
});
83+
}
84+
}
85+
86+
async fn handler(ConnectInfo(addr): ConnectInfo<SocketAddr>) -> String {
87+
addr.to_string()
88+
}

0 commit comments

Comments
 (0)