base

members:

Store, NamespacedStore

class litestar.stores.base.NamespacedStore[source]

Bases: Store

A subclass of Store, offering hierarchical namespacing.

Bulk actions on a parent namespace should affect all child namespaces, whereas other operations on all namespaces should be isolated.

abstractmethod with_namespace(namespace: str) Self[source]

Return a new instance of NamespacedStore, which exists in a child namespace of the current namespace. Bulk actions on the parent namespace should affect all child namespaces, whereas other operations on all namespaces should be isolated.

class litestar.stores.base.StorageObject[source]

Bases: Struct

msgspec.Struct to store serialized data alongside with their expiry time.

classmethod new(data: bytes, expires_in: int | timedelta | None) StorageObject[source]

Construct a new StorageObject instance.

property expired: bool

Return if the StorageObject is expired

property expires_in: int

Return the expiry time of this StorageObject in seconds. If no expiry time was set, return -1.

to_bytes() bytes[source]

Encode the instance to bytes

classmethod from_bytes(raw: bytes) StorageObject[source]

Load a previously encoded with StorageObject.to_bytes()

class litestar.stores.base.Store[source]

Bases: ABC

Thread and process safe asynchronous key/value store.

abstractmethod async set(key: str, value: str | bytes, expires_in: int | timedelta | None = None) None[source]

Set a value.

Parameters:
  • key – Key to associate the value with

  • value – Value to store

  • expires_in – Time in seconds before the key is considered expired

Returns:

None

abstractmethod async get(key: str, renew_for: int | timedelta | None = None) bytes | None[source]

Get a value.

Parameters:
  • key – Key associated with the value

  • renew_for – If given and the value had an initial expiry time set, renew the expiry time for renew_for seconds. If the value has not been set with an expiry time this is a no-op

Returns:

The value associated with key if it exists and is not expired, else None

abstractmethod async delete(key: str) None[source]

Delete a value.

If no such key exists, this is a no-op.

Parameters:

key – Key of the value to delete

abstractmethod async delete_all() None[source]

Delete all stored values.

abstractmethod async exists(key: str) bool[source]

Check if a given key exists.

abstractmethod async expires_in(key: str) int | None[source]

Get the time in seconds key expires in. If no such key exists or no expiry time was set, return None.