use super::KeyStoreOperations;
use crate::biome::key_management::store::diesel::models::KeyModel;
use crate::biome::key_management::store::diesel::schema::keys;
use crate::biome::key_management::{store::KeyStoreError, Key};
use diesel::{dsl::delete, prelude::*, result::Error::NotFound};
pub(in crate::biome::key_management) trait KeyStoreRemoveKeyOperation {
fn remove_key(&self, public_key: &str, user_id: &str) -> Result<Key, KeyStoreError>;
}
impl<'a, C> KeyStoreRemoveKeyOperation for KeyStoreOperations<'a, C>
where
C: diesel::Connection,
String: diesel::deserialize::FromSql<diesel::sql_types::Text, C::Backend>,
{
fn remove_key(&self, public_key: &str, user_id: &str) -> Result<Key, KeyStoreError> {
let key = keys::table
.filter(
keys::public_key
.eq(public_key)
.and(keys::user_id.eq(user_id)),
)
.first::<KeyModel>(self.conn)
.map(Some)
.or_else(|err| if err == NotFound { Ok(None) } else { Err(err) })
.map_err(|err| KeyStoreError::QueryError {
context: "Failed to fetch key by user ID and public key".to_string(),
source: Box::new(err),
})?
.ok_or_else(|| {
KeyStoreError::NotFoundError(format!(
"Failed to find key with public key: {} and user id: {}",
public_key, user_id
))
})?;
delete(
keys::table.filter(
keys::public_key
.eq(public_key)
.and(keys::user_id.eq(user_id)),
),
)
.execute(self.conn)
.map(|_| ())
.map_err(|err| KeyStoreError::OperationError {
context: "Failed to delete key".to_string(),
source: Box::new(err),
})?;
Ok(Key::from(key))
}
}