-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathviews_lnurl.py
85 lines (78 loc) · 2.68 KB
/
views_lnurl.py
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
import json
from http import HTTPStatus
from typing import Union
from fastapi import APIRouter, HTTPException, Query, Request
from lnbits.core.services import create_invoice
from lnbits.lnurl import LnurlErrorResponseHandler
from lnurl import LnurlPayActionResponse, LnurlPayResponse
from lnurl.models import MessageAction
from lnurl.types import (
ClearnetUrl,
DebugUrl,
LightningInvoice,
LnurlPayMetadata,
Max144Str,
MilliSatoshi,
OnionUrl,
)
from pydantic import parse_obj_as
from .crud import (
create_print,
get_printer,
)
pay2print_lnurl_router = APIRouter()
pay2print_lnurl_router.route_class = LnurlErrorResponseHandler
@pay2print_lnurl_router.get(
"/api/v1/lnurl/{printer_id}",
status_code=HTTPStatus.OK,
name="pay2print.api_lnurl_response",
)
async def api_lnurl_response(request: Request, printer_id: str) -> LnurlPayResponse:
printer = await get_printer(printer_id)
if not printer:
raise HTTPException(
status_code=HTTPStatus.NOT_FOUND, detail="Printer does not exist."
)
url = request.url_for("pay2print.api_lnurl_callback", printer_id=printer_id)
callback_url: Union[DebugUrl, OnionUrl, ClearnetUrl] = parse_obj_as(
Union[DebugUrl, OnionUrl, ClearnetUrl], # type: ignore
str(url),
)
return LnurlPayResponse(
callback=callback_url,
minSendable=MilliSatoshi(printer.amount * 1000),
maxSendable=MilliSatoshi(printer.amount * 1000),
metadata=LnurlPayMetadata(
json.dumps([["text/plain", f"Pay to print {printer.name}"]])
),
)
@pay2print_lnurl_router.get(
"/api/v1/lnurl/cb/{printer_id}",
status_code=HTTPStatus.OK,
name="pay2print.api_lnurl_callback",
)
async def api_lnurl_callback(
printer_id: str,
amount: int = Query(...),
) -> LnurlPayActionResponse:
printer = await get_printer(printer_id)
if not printer:
raise HTTPException(
status_code=HTTPStatus.NOT_FOUND, detail="Printer does not exist."
)
if amount != printer.amount:
raise HTTPException(
status_code=HTTPStatus.BAD_REQUEST,
detail=f"Amount must be {printer.amount}.",
)
payment = await create_invoice(
wallet_id=printer.wallet,
amount=printer.amount,
memo=f"Pay to print {printer.name}",
extra={"tag": "pay2print"},
)
await create_print(printer_id, payment.payment_hash, "lnurl.txt")
message = parse_obj_as(Max144Str, "Printing! Thank you")
action = MessageAction(message=message)
invoice = parse_obj_as(LightningInvoice, LightningInvoice(payment.bolt11))
return LnurlPayActionResponse(pr=invoice, successAction=action, routes=[])