2022-10-06 17:10:15 +01:00
|
|
|
import asyncio
|
|
|
|
import json
|
|
|
|
from http import HTTPStatus
|
|
|
|
from urllib.parse import urlparse
|
|
|
|
|
|
|
|
import httpx
|
|
|
|
from fastapi import HTTPException
|
|
|
|
|
|
|
|
from lnbits import bolt11
|
|
|
|
from lnbits.core.models import Payment
|
2022-12-01 18:31:58 +00:00
|
|
|
from lnbits.core.services import pay_invoice, websocketUpdater
|
2022-10-06 17:10:15 +01:00
|
|
|
from lnbits.helpers import get_current_extension_name
|
|
|
|
from lnbits.tasks import register_invoice_listener
|
|
|
|
|
2022-10-27 01:10:03 +01:00
|
|
|
from .crud import get_lnurldevice, get_lnurldevicepayment, update_lnurldevicepayment
|
2022-10-06 17:10:15 +01:00
|
|
|
|
2022-10-07 23:18:57 +01:00
|
|
|
|
2022-10-06 17:10:15 +01:00
|
|
|
async def wait_for_paid_invoices():
|
|
|
|
invoice_queue = asyncio.Queue()
|
|
|
|
register_invoice_listener(invoice_queue, get_current_extension_name())
|
|
|
|
|
|
|
|
while True:
|
|
|
|
payment = await invoice_queue.get()
|
|
|
|
await on_invoice_paid(payment)
|
2022-10-07 23:18:57 +01:00
|
|
|
|
|
|
|
|
2022-10-06 17:10:15 +01:00
|
|
|
async def on_invoice_paid(payment: Payment) -> None:
|
|
|
|
# (avoid loops)
|
2022-10-07 13:46:40 +01:00
|
|
|
if "Switch" == payment.extra.get("tag"):
|
2022-10-06 17:10:15 +01:00
|
|
|
lnurldevicepayment = await get_lnurldevicepayment(payment.extra.get("id"))
|
|
|
|
if not lnurldevicepayment:
|
|
|
|
return
|
|
|
|
if lnurldevicepayment.payhash == "used":
|
|
|
|
return
|
|
|
|
lnurldevicepayment = await update_lnurldevicepayment(
|
2022-10-07 23:18:57 +01:00
|
|
|
lnurldevicepayment_id=payment.extra.get("id"), payhash="used"
|
|
|
|
)
|
2022-12-01 18:31:58 +00:00
|
|
|
return await websocketUpdater(
|
2022-10-27 00:37:15 +01:00
|
|
|
lnurldevicepayment.deviceid,
|
2022-12-01 18:31:58 +00:00
|
|
|
str(lnurldevicepayment.pin) + "-" + str(lnurldevicepayment.payload),
|
2022-10-27 00:37:15 +01:00
|
|
|
)
|
2022-10-07 23:18:57 +01:00
|
|
|
return
|