10 releases (breaking)
0.8.0 | Nov 28, 2023 |
---|---|
0.7.0 | May 23, 2023 |
0.6.0 | Nov 25, 2022 |
0.4.0 | Apr 1, 2022 |
0.1.1 | Nov 21, 2021 |
#2340 in Web programming
339 downloads per month
Used in htmx-components
17KB
313 lines
axum-flash
One-time notifications (aka flash messages) for axum.
More information about this crate can be found in the crate documentation.
lib.rs
:
One-time notifications (aka flash messages) for axum.
Example
use axum::{
response::{IntoResponse, Redirect},
extract::FromRef,
routing::get,
Router,
};
use axum_flash::{IncomingFlashes, Flash, Key};
#[derive(Clone)]
struct AppState {
flash_config: axum_flash::Config,
}
let app_state = AppState {
// The key should probably come from configuration
flash_config: axum_flash::Config::new(Key::generate()),
};
// Our state type must implement this trait. That is how the config
// is passed to axum-flash in a type safe way.
impl FromRef<AppState> for axum_flash::Config {
fn from_ref(state: &AppState) -> axum_flash::Config {
state.flash_config.clone()
}
}
let app = Router::new()
.route("/", get(root))
.route("/set-flash", get(set_flash))
.with_state(app_state);
async fn root(flashes: IncomingFlashes) -> IncomingFlashes {
for (level, text) in &flashes {
// ...
}
// The flashes must be returned so the cookie is removed
flashes
}
async fn set_flash(flash: Flash) -> (Flash, Redirect) {
(
// The flash must be returned so the cookie is set
flash.debug("Hi from flash!"),
Redirect::to("/"),
)
}
Dependencies
~6.5MB
~128K SLoC