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

120 lines
3.8 KiB
Python
Raw Normal View History

from typing import List, Optional
2021-10-14 10:02:02 +01:00
import httpx
2021-10-14 10:02:02 +01:00
from lnbits.core.services import create_invoice
from lnbits.core.views.api import api_payment
2021-10-14 10:02:02 +01:00
from lnbits.helpers import urlsafe_short_hash
from ..watchonly.crud import get_fresh_address, get_mempool, get_watch_wallet
# from lnbits.db import open_ext_db
from . import db
from .models import Charges, CreateCharge
2021-10-14 10:02:02 +01:00
###############CHARGES##########################
2021-10-17 18:33:29 +01:00
async def create_charge(user: str, data: CreateCharge) -> Charges:
2021-10-14 10:02:02 +01:00
charge_id = urlsafe_short_hash()
2021-10-14 11:45:56 +01:00
if data.onchainwallet:
wallet = await get_watch_wallet(data.onchainwallet)
onchain = await get_fresh_address(data.onchainwallet)
2021-10-14 10:02:02 +01:00
onchainaddress = onchain.address
else:
onchainaddress = None
2021-10-14 11:45:56 +01:00
if data.lnbitswallet:
2021-10-14 10:02:02 +01:00
payment_hash, payment_request = await create_invoice(
2021-10-14 11:45:56 +01:00
wallet_id=data.lnbitswallet, amount=data.amount, memo=charge_id
2021-10-14 10:02:02 +01:00
)
else:
payment_hash = None
payment_request = None
await db.execute(
"""
INSERT INTO satspay.charges (
id,
"user",
description,
onchainwallet,
onchainaddress,
lnbitswallet,
payment_request,
payment_hash,
webhook,
completelink,
completelinktext,
time,
amount,
balance
)
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
""",
(
charge_id,
user,
2021-10-14 11:45:56 +01:00
data.description,
data.onchainwallet,
2021-10-14 10:02:02 +01:00
onchainaddress,
2021-10-14 11:45:56 +01:00
data.lnbitswallet,
2021-10-14 10:02:02 +01:00
payment_request,
payment_hash,
2021-10-14 11:45:56 +01:00
data.webhook,
data.completelink,
data.completelinktext,
data.time,
data.amount,
2021-10-14 10:02:02 +01:00
0,
),
)
return await get_charge(charge_id)
async def update_charge(charge_id: str, **kwargs) -> Optional[Charges]:
q = ", ".join([f"{field[0]} = ?" for field in kwargs.items()])
await db.execute(
f"UPDATE satspay.charges SET {q} WHERE id = ?", (*kwargs.values(), charge_id)
)
row = await db.fetchone("SELECT * FROM satspay.charges WHERE id = ?", (charge_id,))
return Charges.from_row(row) if row else None
async def get_charge(charge_id: str) -> Charges:
row = await db.fetchone("SELECT * FROM satspay.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 satspay.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 satspay.charges WHERE id = ?", (charge_id,))
async def check_address_balance(charge_id: str) -> List[Charges]:
charge = await get_charge(charge_id)
if not charge.paid:
if charge.onchainaddress:
mempool = await get_mempool(charge.user)
try:
async with httpx.AsyncClient() as client:
r = await client.get(
mempool.endpoint + "/api/address/" + charge.onchainaddress
)
respAmount = r.json()["chain_stats"]["funded_txo_sum"]
if respAmount >= charge.balance:
await update_charge(charge_id=charge_id, balance=respAmount)
except Exception:
pass
if charge.lnbitswallet:
2021-10-22 00:41:30 +01:00
invoice_status = await api_payment(charge.payment_hash)
if invoice_status["paid"]:
2021-10-14 10:02:02 +01:00
return await update_charge(charge_id=charge_id, balance=charge.amount)
row = await db.fetchone("SELECT * FROM satspay.charges WHERE id = ?", (charge_id,))
return Charges.from_row(row) if row else None