pub struct RedisCacheDatabase {
pub con: ConnectionManager,
pub trader_id: TraderId,
pub trader_key: String,
pub encoding: SerializationEncoding,
/* private fields */
}
Fields§
§con: ConnectionManager
§trader_id: TraderId
§trader_key: String
§encoding: SerializationEncoding
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.
Sourcepub fn update(&mut self, key: String, payload: Option<Vec<Bytes>>) -> Result<()>
pub fn update(&mut self, key: String, payload: Option<Vec<Bytes>>) -> Result<()>
Sends an update 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.
Sourcepub fn delete(&mut self, key: String, payload: Option<Vec<Bytes>>) -> Result<()>
pub fn delete(&mut self, key: String, payload: Option<Vec<Bytes>>) -> Result<()>
Sends a delete 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.
Sourcepub fn delete_order(&self, client_order_id: &ClientOrderId) -> Result<()>
pub fn delete_order(&self, client_order_id: &ClientOrderId) -> Result<()>
Delete the given order from the database with comprehensive index cleanup.
§Errors
Returns an error if the command cannot be sent to the background task channel.
Sourcepub fn delete_position(&self, position_id: &PositionId) -> Result<()>
pub fn delete_position(&self, position_id: &PositionId) -> Result<()>
Delete the given position from the database with comprehensive index cleanup.
§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
Source§type Output = Bound<'py, <RedisCacheDatabase as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <RedisCacheDatabase as IntoPyObject<'py>>::Target>
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>
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
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
Source§type ThreadChecker = SendablePyClass<RedisCacheDatabase>
type ThreadChecker = SendablePyClass<RedisCacheDatabase>
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
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
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
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
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
§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>
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>
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>
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>
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>
self
into a Python object. Read more