lnbits-legend/lnbits/extensions/satspay/crud.py

129 lines
4 KiB
Python
Raw Normal View History

2021-04-04 18:20:52 +01:00
from typing import List, Optional, Union
2021-04-09 00:41:19 +01:00
# from lnbits.db import open_ext_db
2021-04-04 18:20:52 +01:00
from . import db
from .models import Charges
from lnbits.helpers import urlsafe_short_hash
from quart import jsonify
import httpx
from lnbits.core.services import create_invoice, check_invoice_status
2021-04-08 01:34:44 +01:00
from ..watchonly.crud import get_watch_wallet, get_fresh_address, get_mempool
2021-04-04 18:20:52 +01:00
###############CHARGES##########################
2021-04-09 00:41:19 +01:00
async def create_charge(
user: str,
description: str = None,
onchainwallet: Optional[str] = None,
lnbitswallet: Optional[str] = None,
webhook: Optional[str] = None,
completelink: Optional[str] = None,
2021-06-13 13:04:18 +01:00
completelinktext: Optional[str] = "Back to Merchant",
2021-04-09 00:41:19 +01:00
time: Optional[int] = None,
amount: Optional[int] = None,
) -> Charges:
2021-04-04 18:20:52 +01:00
charge_id = urlsafe_short_hash()
if onchainwallet:
wallet = await get_watch_wallet(onchainwallet)
2021-04-09 00:22:52 +01:00
onchain = await get_fresh_address(onchainwallet)
onchainaddress = onchain.address
2021-04-04 18:20:52 +01:00
else:
2021-04-09 00:22:52 +01:00
onchainaddress = None
2021-04-04 18:20:52 +01:00
if lnbitswallet:
payment_hash, payment_request = await create_invoice(
2021-04-09 00:41:19 +01:00
wallet_id=lnbitswallet, amount=amount, memo=charge_id
)
2021-04-04 18:20:52 +01:00
else:
payment_hash = None
payment_request = None
await db.execute(
"""
INSERT INTO charges (
id,
user,
description,
onchainwallet,
onchainaddress,
lnbitswallet,
payment_request,
payment_hash,
webhook,
completelink,
completelinktext,
2021-04-04 18:20:52 +01:00
time,
amount,
2021-04-07 01:50:38 +01:00
balance
2021-04-04 18:20:52 +01:00
)
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
2021-04-04 18:20:52 +01:00
""",
2021-04-09 00:41:19 +01:00
(
charge_id,
user,
description,
onchainwallet,
onchainaddress,
lnbitswallet,
payment_request,
payment_hash,
webhook,
completelink,
completelinktext,
time,
amount,
0,
),
2021-04-04 18:20:52 +01:00
)
return await get_charge(charge_id)
2021-04-05 01:48:35 +01:00
2021-04-04 18:20:52 +01:00
async def update_charge(charge_id: str, **kwargs) -> Optional[Charges]:
q = ", ".join([f"{field[0]} = ?" for field in kwargs.items()])
2021-04-09 00:41:19 +01:00
await db.execute(
f"UPDATE charges SET {q} WHERE id = ?", (*kwargs.values(), charge_id)
)
2021-04-05 01:48:35 +01:00
row = await db.fetchone("SELECT * FROM charges WHERE id = ?", (charge_id,))
2021-04-04 18:20:52 +01:00
return Charges.from_row(row) if row else None
async def get_charge(charge_id: str) -> Charges:
row = await db.fetchone("SELECT * FROM charges WHERE id = ?", (charge_id,))
return Charges.from_row(row) if row else None
async def get_charges(user: str) -> List[Charges]:
rows = await db.fetchall("SELECT * FROM charges WHERE user = ?", (user,))
return [Charges.from_row(row) for row in rows]
async def delete_charge(charge_id: str) -> None:
await db.execute("DELETE FROM charges WHERE id = ?", (charge_id,))
2021-04-05 01:48:35 +01:00
2021-04-04 18:20:52 +01:00
async def check_address_balance(charge_id: str) -> List[Charges]:
charge = await get_charge(charge_id)
2021-04-07 01:50:38 +01:00
if not charge.paid:
if charge.onchainaddress:
mempool = await get_mempool(charge.user)
try:
async with httpx.AsyncClient() as client:
2021-04-09 00:41:19 +01:00
r = await client.get(
mempool.endpoint + "/api/address/" + charge.onchainaddress
)
respAmount = r.json()["chain_stats"]["funded_txo_sum"]
2021-04-07 01:50:38 +01:00
if respAmount >= charge.balance:
await update_charge(charge_id=charge_id, balance=respAmount)
except Exception:
pass
if charge.lnbitswallet:
2021-04-09 00:41:19 +01:00
invoice_status = await check_invoice_status(
charge.lnbitswallet, charge.payment_hash
)
2021-04-07 01:50:38 +01:00
if invoice_status.paid:
return await update_charge(charge_id=charge_id, balance=charge.amount)
2021-04-04 18:20:52 +01:00
row = await db.fetchone("SELECT * FROM charges WHERE id = ?", (charge_id,))
return Charges.from_row(row) if row else None