From c6bcb5822ab73b0149d8c752e882e93026d01d30 Mon Sep 17 00:00:00 2001 From: Ross Savage Date: Wed, 18 Dec 2024 21:54:11 +0100 Subject: [PATCH] Update LNURL structs --- libs/sdk-common/src/lnurl/specs/pay.rs | 4 ++-- libs/sdk-common/src/lnurl/specs/withdraw.rs | 8 ++++++++ 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/libs/sdk-common/src/lnurl/specs/pay.rs b/libs/sdk-common/src/lnurl/specs/pay.rs index 65fc47a5e..3ba18a9a3 100644 --- a/libs/sdk-common/src/lnurl/specs/pay.rs +++ b/libs/sdk-common/src/lnurl/specs/pay.rs @@ -173,7 +173,7 @@ pub mod model { /// Payload of the AES success action, as received from the LNURL endpoint /// /// See [AesSuccessActionDataDecrypted] for a similar wrapper containing the decrypted payload - #[derive(Debug, Deserialize, Serialize)] + #[derive(Clone, Debug, Deserialize, PartialEq, Serialize)] pub struct AesSuccessActionData { /// Contents description, up to 144 characters pub description: String, @@ -243,7 +243,7 @@ pub mod model { /// /// Receiving any other (unsupported) success action type will result in a failed parsing, /// which will abort the LNURL-pay workflow, as per LUD-09. - #[derive(Debug, Deserialize, Serialize)] + #[derive(Clone, Debug, Deserialize, PartialEq, Serialize)] #[serde(rename_all = "camelCase")] #[serde(tag = "tag")] pub enum SuccessAction { diff --git a/libs/sdk-common/src/lnurl/specs/withdraw.rs b/libs/sdk-common/src/lnurl/specs/withdraw.rs index 5a157294f..dbc7afeaa 100644 --- a/libs/sdk-common/src/lnurl/specs/withdraw.rs +++ b/libs/sdk-common/src/lnurl/specs/withdraw.rs @@ -146,6 +146,14 @@ pub mod model { ServiceConnectivity { err: String }, } + impl From for LnUrlWithdrawError { + fn from(err: anyhow::Error) -> Self { + Self::Generic { + err: err.to_string(), + } + } + } + impl From for LnUrlWithdrawError { fn from(value: InvoiceError) -> Self { match value {