Skip to content

Commit fe33ace

Browse files
risssondavepgreene
authored andcommitted
packages/ak-axum/accept/tls: init (goauthentik#21318)
1 parent 66170b6 commit fe33ace

7 files changed

Lines changed: 95 additions & 2 deletions

File tree

Cargo.lock

Lines changed: 29 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

Cargo.toml

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -33,6 +33,7 @@ console-subscriber = "= 0.5.0"
3333
dotenvy = "= 0.15.7"
3434
durstr = "= 0.5.1"
3535
eyre = "= 0.6.12"
36+
futures = "= 0.3.32"
3637
glob = "= 0.3.3"
3738
json-subscriber = "= 0.2.8"
3839
nix = { version = "= 0.31.2", features = ["signal"] }
@@ -72,9 +73,10 @@ serde_with = { version = "= 3.18.0", default-features = false, features = [
7273
"base64",
7374
] }
7475
tempfile = "= 3.27.0"
75-
time = { version = "= 0.3.47", features = ["macros"] }
7676
thiserror = "= 2.0.18"
77+
time = { version = "= 0.3.47", features = ["macros"] }
7778
tokio = { version = "= 1.51.0", features = ["full", "tracing"] }
79+
tokio-rustls = "= 0.26.4"
7880
tokio-util = { version = "= 0.7.18", features = ["full"] }
7981
tower = "= 0.5.3"
8082
tower-http = { version = "= 0.6.8", features = ["timeout"] }

packages/ak-axum/Cargo.toml

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,8 @@ axum-server.workspace = true
1515
axum.workspace = true
1616
durstr.workspace = true
1717
eyre.workspace = true
18+
futures.workspace = true
19+
tokio-rustls.workspace = true
1820
tokio.workspace = true
1921
tower-http.workspace = true
2022
tower.workspace = true

packages/ak-axum/src/accept/mod.rs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
pub mod tls;

packages/ak-axum/src/accept/tls.rs

Lines changed: 54 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,54 @@
1+
use axum::{Extension, middleware::AddExtension};
2+
use axum_server::{accept::Accept, tls_rustls::RustlsAcceptor};
3+
use futures::future::BoxFuture;
4+
use tokio::io::{AsyncRead, AsyncWrite};
5+
use tokio_rustls::{rustls::pki_types::CertificateDer, server::TlsStream};
6+
use tower::Layer as _;
7+
use tracing::instrument;
8+
9+
#[derive(Clone, Debug)]
10+
pub struct TlsState {
11+
pub peer_certificates: Option<Vec<CertificateDer<'static>>>,
12+
}
13+
14+
#[derive(Clone)]
15+
pub(crate) struct TlsAcceptor<A> {
16+
inner: RustlsAcceptor<A>,
17+
}
18+
19+
impl<A> TlsAcceptor<A> {
20+
pub(crate) fn new(inner: RustlsAcceptor<A>) -> Self {
21+
Self { inner }
22+
}
23+
}
24+
25+
impl<A, I, S> Accept<I, S> for TlsAcceptor<A>
26+
where
27+
A: Accept<I, S> + Clone + Send + 'static,
28+
A::Stream: AsyncRead + AsyncWrite + Unpin + Send,
29+
A::Service: Send,
30+
A::Future: Send,
31+
I: AsyncRead + AsyncWrite + Unpin + Send + 'static,
32+
S: Send + 'static,
33+
{
34+
type Future = BoxFuture<'static, std::io::Result<(Self::Stream, Self::Service)>>;
35+
type Service = AddExtension<A::Service, TlsState>;
36+
type Stream = TlsStream<A::Stream>;
37+
38+
#[instrument(skip_all)]
39+
fn accept(&self, stream: I, service: S) -> Self::Future {
40+
let acceptor = self.inner.clone();
41+
42+
Box::pin(async move {
43+
let (stream, service) = acceptor.accept(stream, service).await?;
44+
let server_conn = stream.get_ref().1;
45+
let tls_state = TlsState {
46+
peer_certificates: server_conn.peer_certificates().map(|c| c.to_owned()),
47+
};
48+
49+
let service = Extension(tls_state).layer(service);
50+
51+
Ok((stream, service))
52+
})
53+
}
54+
}

packages/ak-axum/src/lib.rs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,6 @@
11
//! Utilities for working with [`axum`].
22
3+
pub mod accept;
34
pub mod error;
45
pub mod router;
56
pub mod server;

packages/ak-axum/src/server.rs

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,8 @@ use axum_server::{
1212
use eyre::Result;
1313
use tracing::info;
1414

15+
use crate::accept::tls::TlsAcceptor;
16+
1517
async fn run_plain(
1618
arbiter: Arbiter,
1719
name: &str,
@@ -119,7 +121,9 @@ async fn run_tls(
119121
arbiter.add_net_handle(handle.clone()).await;
120122

121123
axum_server::Server::bind(addr)
122-
.acceptor(RustlsAcceptor::new(config).acceptor(DefaultAcceptor::new()))
124+
.acceptor(TlsAcceptor::new(
125+
RustlsAcceptor::new(config).acceptor(DefaultAcceptor::new()),
126+
))
123127
.handle(handle)
124128
.serve(router.into_make_service_with_connect_info::<net::SocketAddr>())
125129
.await?;

0 commit comments

Comments
 (0)