From 089d5b177a31364a307db6e7a970e05cf6bfadcb Mon Sep 17 00:00:00 2001 From: Chris Smith <1979423+chris13524@users.noreply.github.com> Date: Thu, 22 Feb 2024 12:21:43 -0500 Subject: [PATCH] fix: duplicate key registration giving 500 error (#179) --- src/stores/keys.rs | 37 ++++++++++++++++++++++--------------- 1 file changed, 22 insertions(+), 15 deletions(-) diff --git a/src/stores/keys.rs b/src/stores/keys.rs index 80bdcbe..de47722 100644 --- a/src/stores/keys.rs +++ b/src/stores/keys.rs @@ -14,10 +14,17 @@ pub use { }, }; use { - crate::config::Configuration, relay_rpc::auth::cacao::Cacao, - wither::mongodb::options::FindOneAndUpdateOptions, + crate::config::Configuration, + relay_rpc::auth::cacao::Cacao, + wither::{ + mongodb::{self, options::FindOneAndUpdateOptions}, + WitherError, + }, }; +// https://www.mongodb.com/docs/manual/reference/error-codes/#mongodb-error-11000 +const MONGODB_DUPLICATE_KEY_ERROR_CODE: i32 = 11000; + pub type KeysPersistentStorageArc = Arc; #[async_trait] @@ -127,7 +134,6 @@ impl KeysPersistentStorage for MongoPersistentStorage { ) -> Result<(), StoreError> { let filter = doc! { "account": &account, - "identities.identity_key": {"$ne": &identity_key}, }; let mongo_identity = MongoIdentity { @@ -146,18 +152,19 @@ impl KeysPersistentStorage for MongoPersistentStorage { match MongoKeys::find_one_and_update(&self.db, filter, update, option).await { Ok(Some(_)) => Ok(()), Ok(None) => Ok(()), - Err(e) => { - if e.to_string().starts_with( - "Command failed (DuplicateKey): E11000 duplicate key error collection: \ - keyserver.keys index: account_1", - ) - // Todo add better error matching - { - Ok(()) - } else { - Err(StoreError::Database(e)) - } - } + Err(e) => match &e { + WitherError::Mongo(mongo_error) => match mongo_error.kind.as_ref() { + mongodb::error::ErrorKind::Command(command_error) => { + if command_error.code == MONGODB_DUPLICATE_KEY_ERROR_CODE { + Ok(()) + } else { + Err(StoreError::Database(e)) + } + } + _ => Err(StoreError::Database(e)), + }, + _ => Err(StoreError::Database(e)), + }, } }