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
use crate::{
    address::Error as AddressError, psbt::Error as PsbtError, secp256k1::Error as Secp256k1Error, ElectrsError,
};
use bitcoincore_rpc::bitcoin::sighash::Error as SighashError;
use std::sync::PoisonError;
use thiserror::Error;

#[derive(Error, Debug)]
pub enum Error {
    #[error("No previous output for input")]
    NoPrevOut,
    #[error("Cannot use invalid prevout")]
    InvalidPrevOut,
    #[error("Cannot construct address")]
    InvalidAddress,
    #[error("No private key found for address")]
    NoPrivateKey,
    #[error("Not enough inputs to fund transaction")]
    NotEnoughInputs,
    #[error("No change address available")]
    NoChangeAddress,
    #[error("Cannot open key store")]
    CannotOpenKeyStore,

    #[error("Secp256k1Error: {0}")]
    Secp256k1Error(#[from] Secp256k1Error),
    #[error("AddressError: {0}")]
    AddressError(#[from] AddressError),
    #[error("PsbtError: {0}")]
    PsbtError(#[from] PsbtError),

    #[error("ElectrsError: {0}")]
    ElectrsError(#[from] ElectrsError),

    #[error("SighashError: {0}")]
    SighashError(#[from] SighashError),
}

impl<T> From<PoisonError<T>> for Error {
    fn from(_: PoisonError<T>) -> Self {
        Self::CannotOpenKeyStore
    }
}