Crates.io | tower-sessions-moka-store |
lib.rs | tower-sessions-moka-store |
version | 0.14.0 |
source | src |
created_at | 2023-11-12 19:26:42.018473 |
updated_at | 2024-09-03 21:09:25.151033 |
description | Moka session store for `tower-sessions`. |
homepage | https://github.com/maxcountryman/tower-sessions-stores |
repository | https://github.com/maxcountryman/tower-sessions-stores |
max_upload_size | |
id | 1032973 |
size | 50,563 |
Moka session store for `tower-sessions`.
use std::net::SocketAddr;
use axum::{response::IntoResponse, routing::get, Router};
use serde::{Deserialize, Serialize};
use time::Duration;
use tower_sessions::{CachingSessionStore, Expiry, Session, SessionManagerLayer};
use tower_sessions_moka_store::MokaStore;
use tower_sessions_sqlx_store::{sqlx::SqlitePool, SqliteStore};
const COUNTER_KEY: &str = "counter";
#[derive(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 = SqlitePool::connect(":memory:").await?;
let sqlite_store = SqliteStore::new(pool);
sqlite_store.migrate().await?;
let moka_store = MokaStore::new(Some(2000));
let caching_store = CachingSessionStore::new(moka_store, sqlite_store);
let session_layer = SessionManagerLayer::new(caching_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?;
Ok(())
}