From c5fdd35078d19293c24a895715a72c6d35659426 Mon Sep 17 00:00:00 2001 From: Vlad Stan Date: Mon, 19 Dec 2022 19:42:11 +0200 Subject: [PATCH] feat: store mor info about the `webhook` call status --- lnbits/extensions/lnurlp/tasks.py | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/lnbits/extensions/lnurlp/tasks.py b/lnbits/extensions/lnurlp/tasks.py index 19a39a32..5de47f2e 100644 --- a/lnbits/extensions/lnurlp/tasks.py +++ b/lnbits/extensions/lnurlp/tasks.py @@ -49,15 +49,22 @@ async def on_invoice_paid(payment: Payment) -> None: if pay_link.webhook_headers: kwargs["headers"] = json.loads(pay_link.webhook_headers) - r = await client.post(pay_link.webhook_url, **kwargs) - await mark_webhook_sent(payment, r.status_code) + r: httpx.Response = await client.post(pay_link.webhook_url, **kwargs) + await mark_webhook_sent( + payment, r.status_code, r.is_success, r.reason_phrase, r.text + ) except Exception as ex: logger.error(ex) - await mark_webhook_sent(payment, -1) + await mark_webhook_sent(payment, -1, False, "Unexpected Error", str(ex)) -async def mark_webhook_sent(payment: Payment, status: int) -> None: - payment.extra["wh_status"] = status +async def mark_webhook_sent( + payment: Payment, status: int, is_success: bool, reason_phrase="", text="" +) -> None: + payment.extra["wh_status"] = status # keep for backwards compability + payment.extra["wh_success"] = is_success + payment.extra["wh_message"] = reason_phrase + payment.extra["wh_response"] = text await core_db.execute( """