tower-sessions-redis-store

Crates.iotower-sessions-redis-store
lib.rstower-sessions-redis-store
version0.14.0
sourcesrc
created_at2023-11-12 19:24:39.985354
updated_at2024-09-03 21:09:07.514127
descriptionRedis session store for `tower-sessions`.
homepagehttps://github.com/maxcountryman/tower-sessions-stores
repositoryhttps://github.com/maxcountryman/tower-sessions-stores
max_upload_size
id1032972
size61,490
Max Countryman (maxcountryman)

documentation

https://docs.rs/tower-sessions-redis-store

README

tower-sessions-redis-store

Redis via `fred` session store for `tower-sessions`.

🤸 Usage

use std::net::SocketAddr;

use axum::{response::IntoResponse, routing::get, Router};
use serde::{Deserialize, Serialize};
use time::Duration;
use tower_sessions::{Expiry, Session, SessionManagerLayer};
use tower_sessions_redis_store::{fred::prelude::*, RedisStore};

const COUNTER_KEY: &str = "counter";

#[derive(Debug, Serialize, Deserialize, Default)]
struct Counter(usize);

async fn handler(session: Session) -> impl IntoResponse {
    let counter: Counter = session.get(COUNTER_KEY).await.unwrap().unwrap_or_default();
    session.insert(COUNTER_KEY, counter.0 + 1).await.unwrap();
    format!("Current count: {}", counter.0)
}

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let pool = RedisPool::new(RedisConfig::default(), None, None, None, 6)?;

    let redis_conn = pool.connect();
    pool.wait_for_connect().await?;

    let session_store = RedisStore::new(pool);
    let session_layer = SessionManagerLayer::new(session_store)
        .with_secure(false)
        .with_expiry(Expiry::OnInactivity(Duration::seconds(10)));

    let app = Router::new().route("/", get(handler)).layer(session_layer);

    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
    let listener = tokio::net::TcpListener::bind(&addr).await?;
    axum::serve(listener, app.into_make_service()).await?;

    redis_conn.await??;

    Ok(())
}
Commit count: 47

cargo fmt