From ac5d03dd295f99f1895d13ae798320dfa1d4667f Mon Sep 17 00:00:00 2001 From: Louis Tarvin Date: Sun, 22 Sep 2024 15:41:57 +0100 Subject: [PATCH] Allow configuring Redis connections via AsyncConnectionConfig --- redis/src/lib.rs | 32 +++++++++++++++++++++++++++++--- 1 file changed, 29 insertions(+), 3 deletions(-) diff --git a/redis/src/lib.rs b/redis/src/lib.rs index 602fffe..b995be3 100644 --- a/redis/src/lib.rs +++ b/redis/src/lib.rs @@ -36,7 +36,7 @@ use std::{ use deadpool::managed; use redis::{ aio::{ConnectionLike, MultiplexedConnection}, - Client, IntoConnectionInfo, RedisError, RedisResult, + AsyncConnectionConfig, Client, IntoConnectionInfo, RedisError, RedisResult, }; pub use redis; @@ -127,10 +127,20 @@ impl ConnectionLike for Connection { /// [`Manager`] for creating and recycling [`redis`] connections. /// /// [`Manager`]: managed::Manager -#[derive(Debug)] pub struct Manager { client: Client, ping_number: AtomicUsize, + connection_config: AsyncConnectionConfig, +} + +// `redis::AsyncConnectionConfig: !Debug` +impl std::fmt::Debug for Manager { + fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { + f.debug_struct("Manager") + .field("client", &self.client) + .field("ping_number", &self.ping_number) + .finish() + } } impl Manager { @@ -140,9 +150,22 @@ impl Manager { /// /// If establishing a new [`Client`] fails. pub fn new(params: T) -> RedisResult { + Self::from_config(params, AsyncConnectionConfig::default()) + } + + /// Creates a new [`Manager`] from the given `params` and [`AsyncConnectionConfig`]. + /// + /// # Errors + /// + /// If establishing a new [`Client`] fails. + pub fn from_config( + params: T, + connection_config: AsyncConnectionConfig, + ) -> RedisResult { Ok(Self { client: Client::open(params)?, ping_number: AtomicUsize::new(0), + connection_config, }) } } @@ -152,7 +175,10 @@ impl managed::Manager for Manager { type Error = RedisError; async fn create(&self) -> Result { - let conn = self.client.get_multiplexed_async_connection().await?; + let conn = self + .client + .get_multiplexed_async_connection_with_config(&self.connection_config) + .await?; Ok(conn) }