pub struct CachingSessionStore<Cache: SessionStore, Store: SessionStore> { /* private fields */ }
Expand description

A session store for layered caching.

Contains both a cache, which acts as a frontend, and a store which acts as a backend. Both cache and store implement SessionStore.

By using a cache, the cost of reads can be greatly reduced as once cached, reads need only interact with the frontend, forgoing the cost of retrieving the session record from the backend.

Examples

use tower_sessions::{CachingSessionStore, MokaStore, SqlitePool, SqliteStore};
let pool = SqlitePool::connect("sqlite::memory:").await?;
let sqlite_store = SqliteStore::new(pool);
let moka_store = MokaStore::new(Some(2_000));
let caching_store = CachingSessionStore::new(moka_store, sqlite_store);

Implementations§

source§

impl<Cache: SessionStore, Store: SessionStore> CachingSessionStore<Cache, Store>

source

pub fn new(cache: Cache, store: Store) -> Self

Create a new CachingSessionStore.

Trait Implementations§

source§

impl<Cache: Clone + SessionStore, Store: Clone + SessionStore> Clone for CachingSessionStore<Cache, Store>

source§

fn clone(&self) -> CachingSessionStore<Cache, Store>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<Cache: Debug + SessionStore, Store: Debug + SessionStore> Debug for CachingSessionStore<Cache, Store>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Cache, Store> SessionStore for CachingSessionStore<Cache, Store>
where Cache: SessionStore, Store: SessionStore,

source§

fn save<'life0, 'life1, 'async_trait>( &'life0 self, record: &'life1 Record ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

A method for saving a session in a store.
source§

fn load<'life0, 'life1, 'async_trait>( &'life0 self, session_id: &'life1 Id ) -> Pin<Box<dyn Future<Output = Result<Option<Record>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

A method for loading a session from a store.
source§

fn delete<'life0, 'life1, 'async_trait>( &'life0 self, session_id: &'life1 Id ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

A method for deleting a session from a store.

Auto Trait Implementations§

§

impl<Cache, Store> RefUnwindSafe for CachingSessionStore<Cache, Store>
where Cache: RefUnwindSafe, Store: RefUnwindSafe,

§

impl<Cache, Store> Send for CachingSessionStore<Cache, Store>

§

impl<Cache, Store> Sync for CachingSessionStore<Cache, Store>

§

impl<Cache, Store> Unpin for CachingSessionStore<Cache, Store>
where Cache: Unpin, Store: Unpin,

§

impl<Cache, Store> UnwindSafe for CachingSessionStore<Cache, Store>
where Cache: UnwindSafe, Store: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FromRef<T> for T
where T: Clone,

source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more