🥠Cookie-based sessions for axum via async_session.
axum-sessions
is a middleware providing cookie-based sessions for axum
applications.
async_session
, enabling flexible cookie storage (e.g. async-sqlx-session
)ReadableSession
and WritableSession
)To use the crate in your project, add the following to your Cargo.toml
file:
toml
[dependencies]
axum-sessions = "0.3.1"
axum
applications can use the middleware via the session layer.
axum
Example```rust use axum::{routing::get, Router}; use axumsessions::{ asyncsession::MemoryStore, extractors::{ReadableSession, WritableSession}, SessionLayer, }; use rand::Rng;
async fn main() { let store = MemoryStore::new(); let secret = rand::threadrng().gen::<[u8; 128]>(); let sessionlayer = SessionLayer::new(store, &secret);
async fn signin_handler(mut session: WritableSession) {
session
.insert("signed_in", true)
.expect("Could not sign in.");
}
async fn signout_handler(mut session: WritableSession) {
session.destroy();
}
async fn protected_handler(session: ReadableSession) -> &'static str {
if session
.get::<bool>("signed_in")
.map_or(false, |signed_in| signed_in)
{
"Shh, it's secret!"
} else {
"Nothing to see here."
}
}
let app = Router::new()
.route("/signin", get(signin_handler))
.route("/signout", get(signout_handler))
.route("/protected", get(protected_handler))
.layer(session_layer);
axum::Server::bind(&"0.0.0.0:3000".parse().unwrap())
.serve(app.into_make_service())
.await
.unwrap();
} ```
You can find this example as well as other example projects in the example directory.
See the crate documentation for more usage information.