pub struct RedisCacheDatabase {
pub con: ConnectionManager,
pub trader_id: TraderId,
/* private fields */
}
Fields§
§con: ConnectionManager
§trader_id: TraderId
Implementations§
Source§impl RedisCacheDatabase
impl RedisCacheDatabase
Sourcepub async fn new(
trader_id: TraderId,
instance_id: UUID4,
config: CacheConfig,
) -> Result<Self>
pub async fn new( trader_id: TraderId, instance_id: UUID4, config: CacheConfig, ) -> Result<Self>
Creates a new RedisCacheDatabase
instance for the given trader_id
, instance_id
, and config
.
§Errors
Returns an error if:
- The database configuration is missing in
config
. - Establishing the Redis connection fails.
- The command processing task cannot be spawned.
pub const fn get_encoding(&self) -> SerializationEncoding
pub fn get_trader_key(&self) -> &str
pub fn close(&mut self)
pub async fn flushdb(&mut self)
Sourcepub async fn keys(&mut self, pattern: &str) -> Result<Vec<String>>
pub async fn keys(&mut self, pattern: &str) -> Result<Vec<String>>
Retrieves all keys matching the given pattern
from Redis for this trader.
§Errors
Returns an error if the underlying Redis scan operation fails.
Sourcepub async fn read(&mut self, key: &str) -> Result<Vec<Bytes>>
pub async fn read(&mut self, key: &str) -> Result<Vec<Bytes>>
Reads the value(s) associated with key
for this trader from Redis.
§Errors
Returns an error if the underlying Redis read operation fails.
Sourcepub fn insert(&mut self, key: String, payload: Option<Vec<Bytes>>) -> Result<()>
pub fn insert(&mut self, key: String, payload: Option<Vec<Bytes>>) -> Result<()>
Sends an insert command for key
with optional payload
to Redis via the background task.
§Errors
Returns an error if the command cannot be sent to the background task channel.
Trait Implementations§
Source§impl Debug for RedisCacheDatabase
impl Debug for RedisCacheDatabase
Source§impl<'py> IntoPyObject<'py> for RedisCacheDatabase
impl<'py> IntoPyObject<'py> for RedisCacheDatabase
Source§type Target = RedisCacheDatabase
type Target = RedisCacheDatabase
The Python output type
Source§type Output = Bound<'py, <RedisCacheDatabase as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <RedisCacheDatabase as IntoPyObject<'py>>::Target>
The smart pointer type to use. Read more
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Performs the conversion.
Source§impl PyClass for RedisCacheDatabase
impl PyClass for RedisCacheDatabase
Source§impl PyClassImpl for RedisCacheDatabase
impl PyClassImpl for RedisCacheDatabase
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
#[pyclass(subclass)]
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
#[pyclass(extends=…)]
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
#[pyclass(mapping)]
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
#[pyclass(sequence)]
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
#[pyclass(immutable_type)]
Source§type ThreadChecker = SendablePyClass<RedisCacheDatabase>
type ThreadChecker = SendablePyClass<RedisCacheDatabase>
This handles following two situations: Read more
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Immutable or mutable
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
The closest native ancestor. This is
PyAny
by default, and when you declare
#[pyclass(extends=PyDict)]
, it’s PyDict
.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
fn dict_offset() -> Option<isize>
fn weaklist_offset() -> Option<isize>
Source§impl PyClassNewTextSignature<RedisCacheDatabase> for PyClassImplCollector<RedisCacheDatabase>
impl PyClassNewTextSignature<RedisCacheDatabase> for PyClassImplCollector<RedisCacheDatabase>
fn new_text_signature(self) -> Option<&'static str>
Source§impl<'a, 'py> PyFunctionArgument<'a, 'py, false> for &'a RedisCacheDatabase
impl<'a, 'py> PyFunctionArgument<'a, 'py, false> for &'a RedisCacheDatabase
Source§impl<'a, 'py> PyFunctionArgument<'a, 'py, false> for &'a mut RedisCacheDatabase
impl<'a, 'py> PyFunctionArgument<'a, 'py, false> for &'a mut RedisCacheDatabase
Source§impl PyMethods<RedisCacheDatabase> for PyClassImplCollector<RedisCacheDatabase>
impl PyMethods<RedisCacheDatabase> for PyClassImplCollector<RedisCacheDatabase>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for RedisCacheDatabase
impl PyTypeInfo for RedisCacheDatabase
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
Returns the PyTypeObject instance for this type.
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
Returns the safe abstraction over the type object.
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
Checks if
object
is an instance of this type or a subclass of this type.§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
Checks if
object
is an instance of this type.impl DerefToPyAny for RedisCacheDatabase
Auto Trait Implementations§
impl Freeze for RedisCacheDatabase
impl !RefUnwindSafe for RedisCacheDatabase
impl Send for RedisCacheDatabase
impl Sync for RedisCacheDatabase
impl Unpin for RedisCacheDatabase
impl !UnwindSafe for RedisCacheDatabase
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
Converts
self
into an owned Python object, dropping type information.§fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
Converts
self
into an owned Python object, dropping type information and unbinding it
from the 'py
lifetime.§fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
Converts
self
into a Python object. Read more