use std::fmt;
use bitcoin::secp256k1::PublicKey;
#[derive(Clone, PartialEq, Eq, PartialOrd, Ord, thiserror::Error)]
#[error("incorrect signing key: required={required:?}, provided={provided}")]
pub struct IncorrectSigningKeyError {
pub required: Option<PublicKey>,
pub provided: PublicKey,
}
impl fmt::Debug for IncorrectSigningKeyError {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
f.debug_struct("IncorrectSigningKeyError")
.field("required", &self.required.map(|pk| pk.to_string()).unwrap_or("None".into()))
.field("provided", &self.provided.to_string())
.finish()
}
}