use std::{
collections::HashMap,
sync::{Arc, RwLock},
};
use iroh::{KeyParsingError, PublicKey};
use crate::{AuthorId, AuthorPublicKey, NamespaceId, NamespacePublicKey};
pub trait PublicKeyStore {
fn public_key(&self, id: &[u8; 32]) -> Result<PublicKey, KeyParsingError>;
fn namespace_key(&self, bytes: &NamespaceId) -> Result<NamespacePublicKey, KeyParsingError> {
self.public_key(bytes.as_bytes()).map(Into::into)
}
fn author_key(&self, bytes: &AuthorId) -> Result<AuthorPublicKey, KeyParsingError> {
self.public_key(bytes.as_bytes()).map(Into::into)
}
}
impl<T: PublicKeyStore> PublicKeyStore for &T {
fn public_key(&self, id: &[u8; 32]) -> Result<PublicKey, KeyParsingError> {
(*self).public_key(id)
}
}
impl<T: PublicKeyStore> PublicKeyStore for &mut T {
fn public_key(&self, id: &[u8; 32]) -> Result<PublicKey, KeyParsingError> {
PublicKeyStore::public_key(*self, id)
}
}
impl PublicKeyStore for () {
fn public_key(&self, id: &[u8; 32]) -> Result<PublicKey, KeyParsingError> {
PublicKey::from_bytes(id)
}
}
#[derive(Debug, Clone, Default)]
pub struct MemPublicKeyStore {
keys: Arc<RwLock<HashMap<[u8; 32], PublicKey>>>,
}
impl PublicKeyStore for MemPublicKeyStore {
fn public_key(&self, bytes: &[u8; 32]) -> Result<PublicKey, KeyParsingError> {
if let Some(id) = self.keys.read().unwrap().get(bytes) {
return Ok(*id);
}
let id = PublicKey::from_bytes(bytes)?;
self.keys.write().unwrap().insert(*bytes, id);
Ok(id)
}
}