use super::KeyStoreOperations;
use crate::biome::key_management::store::diesel::schema::keys;
use crate::biome::key_management::store::KeyStoreError;
use diesel::prelude::*;
pub(in crate::biome::key_management) trait KeyStoreUpdateKeyOperation {
fn update_key(
&self,
public_key: &str,
user_id: &str,
display_name: &str,
) -> Result<(), KeyStoreError>;
}
impl<'a, C> KeyStoreUpdateKeyOperation for KeyStoreOperations<'a, C>
where
C: diesel::Connection,
String: diesel::deserialize::FromSql<diesel::sql_types::Text, C::Backend>,
{
fn update_key(
&self,
public_key: &str,
user_id: &str,
display_name: &str,
) -> Result<(), KeyStoreError> {
match diesel::update(keys::table.find((public_key, user_id)))
.set((keys::display_name.eq(display_name),))
.execute(self.conn)
.map_err(|err| KeyStoreError::OperationError {
context: "Failed to update key".to_string(),
source: Box::new(err),
})? {
0 => Err(KeyStoreError::NotFoundError(format!(
"Key with public key {} and user ID {} not found",
public_key, user_id
))),
_ => Ok(()),
}
}
}