From 0409f9e2dc2e260e8bab594218551a289f67f418 Mon Sep 17 00:00:00 2001 From: janskiba Date: Fri, 10 Nov 2023 14:59:52 +0000 Subject: [PATCH] fix: Deadlock on startup --- shared/src/crypto.rs | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/shared/src/crypto.rs b/shared/src/crypto.rs index 49fc0d77..8204746b 100644 --- a/shared/src/crypto.rs +++ b/shared/src/crypto.rs @@ -107,7 +107,7 @@ impl AsRef for CertificateCacheUpdate { pub struct CertificateCache { serial_to_x509: HashMap, cn_to_serial: HashMap>, - update_trigger: mpsc::Sender>>, + update_trigger: mpsc::UnboundedSender>>, root_cert: Option, // Might not be available at initialization time im_cert: Option, // Might not be available at initialization time } @@ -125,7 +125,7 @@ pub trait GetCerts: Sync + Send { impl CertificateCache { pub fn new( - update_trigger: mpsc::Sender>>, + update_trigger: mpsc::UnboundedSender>>, ) -> CertificateCache { Self { serial_to_x509: HashMap::new(), @@ -256,7 +256,6 @@ impl CertificateCache { .await .update_trigger .send(tx) - .await .expect("Internal Error: Certificate Store Updater is not listening for requests."); debug!("Certificate update triggered -- waiting for results..."); match rx.await { @@ -514,7 +513,7 @@ pub async fn get_im_cert() -> Result { #[dynamic(lazy)] pub(crate) static CERT_CACHE: Arc> = { - let (tx_refresh, mut rx_refresh) = mpsc::channel::>>(16); + let (tx_refresh, mut rx_refresh) = mpsc::unbounded_channel::>>(); let (tx_newcerts, mut rx_newcerts) = mpsc::channel::<()>(1); let cc = Arc::new(RwLock::new(CertificateCache::new(tx_refresh))); let cc2 = cc.clone(); @@ -942,7 +941,7 @@ mod tests { .collect(); let n = certs.len(); - let (tx, rx) = mpsc::channel(1); + let (tx, rx) = mpsc::unbounded_channel(); let cert_cache = CertificateCache { serial_to_x509: certs, update_trigger: tx, @@ -964,7 +963,7 @@ mod tests { #[test] fn test_revokation() { - let mut cache = CertificateCache::new(mpsc::channel(1).0); + let mut cache = CertificateCache::new(mpsc::unbounded_channel().0); let mut certs: Vec<_> = [1, 5, 10].into_iter() .map(Duration::from_secs) .map(build_x509)