1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
// BP Core Library implementing LNP/BP specifications & standards related to
// bitcoin protocol
//
// Written in 2020-2021 by
// Dr. Maxim Orlovsky <orlovsky@pandoracore.com>
//
// To the extent possible under law, the author(s) have dedicated all
// copyright and related and neighboring rights to this software to
// the public domain worldwide. This software is distributed without
// any warranty.
//
// You should have received a copy of the Apache 2.0 License
// along with this software.
// If not, see <https://opensource.org/licenses/Apache-2.0>.
use crate::lnpbp1;
/// Different error types which may happen during deterministic bitcoin
/// commitment generation procedures
#[derive(Clone, Copy, PartialEq, Eq, Debug, Display, Error, From)]
#[display(doc_comments)]
pub enum Error {
/// Indicates failure of applying commitment tweak to a public key
#[from]
Lnpbp1Commitment(lnpbp1::Error),
/// Unable to verify commitment due to an incorrect proof data structure
InvalidProofStructure,
/// LNPBP-2 standard requires OP_RETURN-based commitments to be produced
/// only if serialized version of a tweaked pubkey starts with `02` byte.
/// This error indicates that the provided public key does not satisfy this
/// condition
InvalidOpReturnKey,
/// Can't deserealized public key from bitcoin script push op code
InvalidKeyData,
/// Wrong witness version, may be you need to upgrade used library version
UnsupportedWitnessVersion,
/// Miniscript was unable to parse provided script data; they are either
/// invalid or miniscript library contains a bug
#[from(bitcoin_scripts::PubkeyParseError)]
LockscriptParseError,
/// Provided script contains no keys, so commitment or its verification is
/// impossible
LockscriptContainsNoKeys,
/// Bitcoin script contains public key hashes with no matching public
/// keys provided. Commitment procedure fails since it can't ensure that
/// commitment include all public key.
LockscriptContainsUnknownHashes,
/// Attempt to commit into LockScript has failed: the key that must contain
/// the commitment/tweak was not found either in plain nor hash form in
/// any of the script branches
LockscriptKeyNotFound,
/// Policy compilation error
#[from]
#[display(inner)]
PolicyCompilation(miniscript::policy::compiler::CompilerError),
/// Deterministic bitcoin commitments require use of compressed public keys
UncompressedKey,
}
impl From<descriptors::Error> for Error {
fn from(err: descriptors::Error) -> Self {
match err {
descriptors::Error::InvalidKeyData => Error::InvalidKeyData,
descriptors::Error::UnsupportedWitnessVersion => {
Error::UnsupportedWitnessVersion
}
descriptors::Error::PolicyCompilation(err) => {
Error::PolicyCompilation(err)
}
descriptors::Error::UncompressedKeyInSegWitContext => {
Error::UncompressedKey
}
// Since we never parse strings, this error must not happen
descriptors::Error::CantParseDescriptor => unreachable!(),
// If other errors appear this must crash so we know about that the
// new implementation is required
_ => unimplemented!(),
}
}
}