pub use k256::{EncodedPoint as PublicKey, ecdsa::Signature};
use crate::{
error::{Error, ErrorKind::*},
keyring::SigningProvider,
prelude::*,
};
use cometbft::CometbftKey;
use std::sync::Arc;
#[derive(Clone)]
#[allow(clippy::redundant_allocation)]
pub struct Signer {
provider: SigningProvider,
public_key: CometbftKey,
signer: Arc<Box<dyn signature::Signer<Signature> + Send + Sync>>,
}
impl Signer {
pub fn new(
provider: SigningProvider,
public_key: CometbftKey,
signer: Box<dyn signature::Signer<Signature> + Send + Sync>,
) -> Self {
Self {
provider,
public_key,
signer: Arc::new(signer),
}
}
pub fn public_key(&self) -> CometbftKey {
self.public_key
}
pub fn provider(&self) -> SigningProvider {
self.provider
}
pub fn sign(&self, msg: &[u8]) -> Result<Signature, Error> {
Ok(self
.signer
.try_sign(msg)
.map_err(|e| format_err!(SigningError, "{}", e))?)
}
}