mirror of
https://github.com/aljazceru/breez-sdk-liquid.git
synced 2025-12-31 12:54:31 +01:00
* Get payment by destination * CI fixes * Remove claim_address from query * Add PaymentDestination enum * Add payment hash as a payment query option * Bump Flutter dependencies * Move destination/address queries to list_payments * Apply suggestions from code review Co-authored-by: yse <70684173+hydra-yse@users.noreply.github.com> --------- Co-authored-by: yse <70684173+hydra-yse@users.noreply.github.com>
212 lines
5.2 KiB
Rust
212 lines
5.2 KiB
Rust
use anyhow::Error;
|
|
use lwk_wollet::secp256k1;
|
|
use sdk_common::prelude::LnUrlAuthError;
|
|
|
|
pub type SdkResult<T, E = SdkError> = Result<T, E>;
|
|
|
|
#[macro_export]
|
|
macro_rules! ensure_sdk {
|
|
($cond:expr, $err:expr) => {
|
|
if !$cond {
|
|
return Err($err);
|
|
}
|
|
};
|
|
}
|
|
|
|
// TODO Unify error enum
|
|
#[derive(Debug, thiserror::Error)]
|
|
pub enum SdkError {
|
|
#[error("Liquid SDK instance is already running")]
|
|
AlreadyStarted,
|
|
|
|
#[error("Error: {err}")]
|
|
Generic { err: String },
|
|
|
|
#[error("Liquid SDK instance is not running")]
|
|
NotStarted,
|
|
|
|
#[error("Service connectivity: {err}")]
|
|
ServiceConnectivity { err: String },
|
|
}
|
|
impl SdkError {
|
|
pub fn generic<T: AsRef<str>>(err: T) -> Self {
|
|
Self::Generic {
|
|
err: err.as_ref().to_string(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<anyhow::Error> for SdkError {
|
|
fn from(e: Error) -> Self {
|
|
SdkError::generic(e.to_string())
|
|
}
|
|
}
|
|
|
|
impl From<boltz_client::error::Error> for SdkError {
|
|
fn from(err: boltz_client::error::Error) -> Self {
|
|
match err {
|
|
boltz_client::error::Error::HTTP(e) => {
|
|
SdkError::generic(format!("Could not contact servers: {e:?}"))
|
|
}
|
|
_ => SdkError::generic(format!("{err:?}")),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<secp256k1::Error> for SdkError {
|
|
fn from(err: secp256k1::Error) -> Self {
|
|
SdkError::generic(format!("{err:?}"))
|
|
}
|
|
}
|
|
|
|
#[derive(thiserror::Error, Debug)]
|
|
pub enum PaymentError {
|
|
#[error("The specified funds have already been claimed")]
|
|
AlreadyClaimed,
|
|
|
|
#[error("The specified funds have already been sent")]
|
|
AlreadyPaid,
|
|
|
|
#[error("The payment is already in progress")]
|
|
PaymentInProgress,
|
|
|
|
#[error("Amount is out of range")]
|
|
AmountOutOfRange,
|
|
|
|
#[error("Amount is missing: {err}")]
|
|
AmountMissing { err: String },
|
|
|
|
#[error("Invalid network: {err}")]
|
|
InvalidNetwork { err: String },
|
|
|
|
#[error("Generic error: {err}")]
|
|
Generic { err: String },
|
|
|
|
#[error("The provided fees have expired")]
|
|
InvalidOrExpiredFees,
|
|
|
|
#[error("Cannot pay: not enough funds")]
|
|
InsufficientFunds,
|
|
|
|
#[error("Invalid description: {err}")]
|
|
InvalidDescription { err: String },
|
|
|
|
#[error("The specified invoice is not valid: {err}")]
|
|
InvalidInvoice { err: String },
|
|
|
|
#[error("The generated preimage is not valid")]
|
|
InvalidPreimage,
|
|
|
|
#[error("Lwk error: {err}")]
|
|
LwkError { err: String },
|
|
|
|
#[error("Boltz did not return any pairs from the request")]
|
|
PairsNotFound,
|
|
|
|
#[error("The payment timed out")]
|
|
PaymentTimeout,
|
|
|
|
#[error("Could not store the swap details locally")]
|
|
PersistError,
|
|
|
|
#[error("Could not process the Receive Payment: {err}")]
|
|
ReceiveError { err: String },
|
|
|
|
#[error("The payment has been refunded. Reason for failure: {err}")]
|
|
Refunded { err: String, refund_tx_id: String },
|
|
|
|
#[error("The payment is a self-transfer, which is not supported")]
|
|
SelfTransferNotSupported,
|
|
|
|
#[error("Could not process the Send Payment: {err}")]
|
|
SendError { err: String },
|
|
|
|
#[error("Could not sign the transaction: {err}")]
|
|
SignerError { err: String },
|
|
}
|
|
impl PaymentError {
|
|
pub(crate) fn invalid_invoice(err: &str) -> Self {
|
|
Self::InvalidInvoice {
|
|
err: err.to_string(),
|
|
}
|
|
}
|
|
|
|
pub(crate) fn receive_error(err: &str) -> Self {
|
|
Self::ReceiveError {
|
|
err: err.to_string(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<boltz_client::error::Error> for PaymentError {
|
|
fn from(err: boltz_client::error::Error) -> Self {
|
|
match err {
|
|
boltz_client::error::Error::HTTP(e) => PaymentError::Generic {
|
|
err: format!("Could not contact servers: {e:?}"),
|
|
},
|
|
_ => PaymentError::Generic {
|
|
err: format!("{err:?}"),
|
|
},
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<boltz_client::bitcoin::hex::HexToArrayError> for PaymentError {
|
|
fn from(err: boltz_client::bitcoin::hex::HexToArrayError) -> Self {
|
|
PaymentError::Generic {
|
|
err: format!("{err:?}"),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<lwk_wollet::Error> for PaymentError {
|
|
fn from(err: lwk_wollet::Error) -> Self {
|
|
match err {
|
|
lwk_wollet::Error::InsufficientFunds => PaymentError::InsufficientFunds,
|
|
_ => PaymentError::LwkError {
|
|
err: format!("{err:?}"),
|
|
},
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<lwk_signer::SignerError> for PaymentError {
|
|
fn from(err: lwk_signer::SignerError) -> Self {
|
|
PaymentError::SignerError {
|
|
err: format!("{err:?}"),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<anyhow::Error> for PaymentError {
|
|
fn from(err: anyhow::Error) -> Self {
|
|
Self::Generic {
|
|
err: err.to_string(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<SdkError> for PaymentError {
|
|
fn from(err: SdkError) -> Self {
|
|
Self::Generic {
|
|
err: err.to_string(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<crate::bitcoin::util::bip32::Error> for PaymentError {
|
|
fn from(err: crate::bitcoin::util::bip32::Error) -> Self {
|
|
Self::SignerError {
|
|
err: err.to_string(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<PaymentError> for LnUrlAuthError {
|
|
fn from(value: PaymentError) -> Self {
|
|
Self::Generic {
|
|
err: format!("Failed to perform LNURL-auth: {value:?}"),
|
|
}
|
|
}
|
|
}
|