#axum #kerberos #gssapi #ntlm

axum-negotiate-layer

Negotiate HTTP layer library for axum

4 releases

0.2.0 Jan 2, 2025
0.1.3 Jan 1, 2025
0.1.2 Dec 20, 2024
0.1.1 Dec 20, 2024
0.1.0 Dec 19, 2024

#287 in Authentication

Download history 214/week @ 2024-12-14 130/week @ 2024-12-21 260/week @ 2024-12-28 53/week @ 2025-01-04

657 downloads per month

MIT license

18KB
269 lines

axum-negotiate-layer

This crate provides an axum-compatible tower service and layer to authenticate connections using the Microsoft "HTTP Negotiate" protocol.

use axum::{routing::get, Extension, Router};
use axum_negotiate_layer::{Authenticated, NegotiateInfo, NegotiateLayer};
use tokio::net::TcpListener;

#[tokio::main]
async fn main() {
    let router = Router::new()
        .route("/", get(hello))
        .layer(NegotiateLayer::new("HTTP/example.com"))
        .into_make_service_with_connect_info::<NegotiateInfo>();
    let listener = TcpListener::bind("0.0.0.0:80").await.unwrap().with_negotiate_info();
    axum::serve(listener, router).await.unwrap();
}

async fn hello(Extension(a): Extension<Authenticated>) -> String {
    format!("Hello, {}!", a.client().unwrap_or("whoever"))
}

Dependencies

This crate uses the cross-krb5 crate for Kerberos/Negotiate authentication.

Contributing

I will take contributions as they come and will try to support this crate further along, depending on the needs of submissions. Feel free to ask for features or fixes!

Planned Features

  • Finer behaviour control

Dependencies

~6–35MB
~523K SLoC