2020-05-08 21:03:18 +01:00
|
|
|
from typing import List, Optional, Union
|
|
|
|
|
|
|
|
from lnbits.helpers import urlsafe_short_hash
|
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
from . import db
|
2020-05-08 21:03:18 +01:00
|
|
|
from .models import Tickets, Forms
|
2020-11-30 14:59:21 +00:00
|
|
|
import httpx
|
2020-05-08 21:03:18 +01:00
|
|
|
|
2020-12-31 18:50:16 +01:00
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
async def create_ticket(
|
2020-11-21 23:23:11 -03:00
|
|
|
payment_hash: str,
|
|
|
|
wallet: str,
|
|
|
|
form: str,
|
|
|
|
name: str,
|
|
|
|
email: str,
|
|
|
|
ltext: str,
|
|
|
|
sats: int,
|
2020-11-21 18:04:39 -03:00
|
|
|
) -> Tickets:
|
|
|
|
await db.execute(
|
|
|
|
"""
|
2021-06-21 23:22:52 -03:00
|
|
|
INSERT INTO lnticket.ticket (id, form, email, ltext, name, wallet, sats, paid)
|
2020-11-21 18:04:39 -03:00
|
|
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?)
|
|
|
|
""",
|
|
|
|
(payment_hash, form, email, ltext, name, wallet, sats, False),
|
|
|
|
)
|
2020-05-08 21:03:18 +01:00
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
ticket = await get_ticket(payment_hash)
|
|
|
|
assert ticket, "Newly created ticket couldn't be retrieved"
|
|
|
|
return ticket
|
2020-08-30 23:19:43 -03:00
|
|
|
|
2020-08-10 19:06:56 +01:00
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
async def set_ticket_paid(payment_hash: str) -> Tickets:
|
2021-06-21 23:22:52 -03:00
|
|
|
row = await db.fetchone("SELECT * FROM lnticket.ticket WHERE id = ?", (payment_hash,))
|
2020-11-21 18:04:39 -03:00
|
|
|
if row[7] == False:
|
|
|
|
await db.execute(
|
2020-05-08 21:03:18 +01:00
|
|
|
"""
|
2021-06-21 23:22:52 -03:00
|
|
|
UPDATE lnticket.ticket
|
2020-11-21 18:04:39 -03:00
|
|
|
SET paid = true
|
2020-08-10 19:06:56 +01:00
|
|
|
WHERE id = ?
|
2020-05-08 21:03:18 +01:00
|
|
|
""",
|
2020-11-21 18:04:39 -03:00
|
|
|
(payment_hash,),
|
2020-05-08 21:03:18 +01:00
|
|
|
)
|
2020-08-30 23:19:43 -03:00
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
formdata = await get_form(row[1])
|
|
|
|
assert formdata, "Couldn't get form from paid ticket"
|
|
|
|
|
2020-08-10 19:06:56 +01:00
|
|
|
amount = formdata.amountmade + row[7]
|
2020-11-21 18:04:39 -03:00
|
|
|
await db.execute(
|
2020-05-08 21:03:18 +01:00
|
|
|
"""
|
2021-06-21 23:22:52 -03:00
|
|
|
UPDATE lnticket.form
|
2020-05-08 21:03:18 +01:00
|
|
|
SET amountmade = ?
|
|
|
|
WHERE id = ?
|
|
|
|
""",
|
2020-08-13 23:43:42 +01:00
|
|
|
(amount, row[1]),
|
2020-05-08 21:03:18 +01:00
|
|
|
)
|
2020-12-31 18:50:16 +01:00
|
|
|
|
2020-11-30 14:59:21 +00:00
|
|
|
ticket = await get_ticket(payment_hash)
|
2021-04-10 18:06:41 -03:00
|
|
|
assert ticket, "Newly paid ticket could not be retrieved"
|
|
|
|
|
2020-12-01 22:35:06 +00:00
|
|
|
if formdata.webhook:
|
|
|
|
async with httpx.AsyncClient() as client:
|
2021-04-10 18:06:41 -03:00
|
|
|
await client.post(
|
|
|
|
formdata.webhook,
|
|
|
|
json={
|
|
|
|
"form": ticket.form,
|
|
|
|
"name": ticket.name,
|
|
|
|
"email": ticket.email,
|
|
|
|
"content": ticket.ltext,
|
|
|
|
},
|
|
|
|
timeout=40,
|
|
|
|
)
|
2020-12-01 22:35:06 +00:00
|
|
|
return ticket
|
2021-04-10 18:06:41 -03:00
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
ticket = await get_ticket(payment_hash)
|
2021-04-10 18:06:41 -03:00
|
|
|
assert ticket, "Newly paid ticket could not be retrieved"
|
|
|
|
return ticket
|
2020-08-30 23:19:43 -03:00
|
|
|
|
2020-05-08 21:03:18 +01:00
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
async def get_ticket(ticket_id: str) -> Optional[Tickets]:
|
2021-06-21 23:22:52 -03:00
|
|
|
row = await db.fetchone("SELECT * FROM lnticket.ticket WHERE id = ?", (ticket_id,))
|
2020-05-08 21:03:18 +01:00
|
|
|
return Tickets(**row) if row else None
|
|
|
|
|
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
async def get_tickets(wallet_ids: Union[str, List[str]]) -> List[Tickets]:
|
2020-05-08 21:03:18 +01:00
|
|
|
if isinstance(wallet_ids, str):
|
|
|
|
wallet_ids = [wallet_ids]
|
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
q = ",".join(["?"] * len(wallet_ids))
|
2021-03-24 00:40:32 -03:00
|
|
|
rows = await db.fetchall(
|
2021-06-21 23:22:52 -03:00
|
|
|
f"SELECT * FROM lnticket.ticket WHERE wallet IN ({q})", (*wallet_ids,)
|
2021-03-24 00:40:32 -03:00
|
|
|
)
|
2020-05-08 21:03:18 +01:00
|
|
|
|
|
|
|
return [Tickets(**row) for row in rows]
|
|
|
|
|
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
async def delete_ticket(ticket_id: str) -> None:
|
2021-06-21 23:22:52 -03:00
|
|
|
await db.execute("DELETE FROM lnticket.ticket WHERE id = ?", (ticket_id,))
|
2020-05-08 21:03:18 +01:00
|
|
|
|
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
# FORMS
|
2020-05-08 21:03:18 +01:00
|
|
|
|
|
|
|
|
2020-12-31 18:50:16 +01:00
|
|
|
async def create_form(
|
2021-03-24 00:40:32 -03:00
|
|
|
*,
|
|
|
|
wallet: str,
|
|
|
|
name: str,
|
|
|
|
webhook: Optional[str] = None,
|
|
|
|
description: str,
|
|
|
|
costpword: int,
|
2020-12-31 18:50:16 +01:00
|
|
|
) -> Forms:
|
2020-11-21 18:04:39 -03:00
|
|
|
form_id = urlsafe_short_hash()
|
|
|
|
await db.execute(
|
|
|
|
"""
|
2021-06-21 23:22:52 -03:00
|
|
|
INSERT INTO lnticket.form (id, wallet, name, webhook, description, costpword, amountmade)
|
2020-11-30 14:02:17 +00:00
|
|
|
VALUES (?, ?, ?, ?, ?, ?, ?)
|
2020-11-21 18:04:39 -03:00
|
|
|
""",
|
2020-11-30 14:02:17 +00:00
|
|
|
(form_id, wallet, name, webhook, description, costpword, 0),
|
2020-11-21 18:04:39 -03:00
|
|
|
)
|
2020-05-08 21:03:18 +01:00
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
form = await get_form(form_id)
|
|
|
|
assert form, "Newly created form couldn't be retrieved"
|
|
|
|
return form
|
2020-05-08 21:03:18 +01:00
|
|
|
|
2020-08-30 23:19:43 -03:00
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
async def update_form(form_id: str, **kwargs) -> Forms:
|
2020-05-08 21:03:18 +01:00
|
|
|
q = ", ".join([f"{field[0]} = ?" for field in kwargs.items()])
|
2021-06-21 23:22:52 -03:00
|
|
|
await db.execute(f"UPDATE lnticket.form SET {q} WHERE id = ?", (*kwargs.values(), form_id))
|
|
|
|
row = await db.fetchone("SELECT * FROM lnticket.form WHERE id = ?", (form_id,))
|
2020-11-21 18:04:39 -03:00
|
|
|
assert row, "Newly updated form couldn't be retrieved"
|
|
|
|
return Forms(**row)
|
2020-05-08 21:03:18 +01:00
|
|
|
|
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
async def get_form(form_id: str) -> Optional[Forms]:
|
2021-06-21 23:22:52 -03:00
|
|
|
row = await db.fetchone("SELECT * FROM lnticket.form WHERE id = ?", (form_id,))
|
2020-05-08 21:03:18 +01:00
|
|
|
return Forms(**row) if row else None
|
|
|
|
|
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
async def get_forms(wallet_ids: Union[str, List[str]]) -> List[Forms]:
|
2020-05-08 21:03:18 +01:00
|
|
|
if isinstance(wallet_ids, str):
|
|
|
|
wallet_ids = [wallet_ids]
|
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
q = ",".join(["?"] * len(wallet_ids))
|
2021-03-24 00:40:32 -03:00
|
|
|
rows = await db.fetchall(
|
2021-06-21 23:22:52 -03:00
|
|
|
f"SELECT * FROM lnticket.form WHERE wallet IN ({q})", (*wallet_ids,)
|
2021-03-24 00:40:32 -03:00
|
|
|
)
|
2020-05-08 21:03:18 +01:00
|
|
|
|
|
|
|
return [Forms(**row) for row in rows]
|
|
|
|
|
|
|
|
|
2020-11-21 18:04:39 -03:00
|
|
|
async def delete_form(form_id: str) -> None:
|
2021-06-21 23:22:52 -03:00
|
|
|
await db.execute("DELETE FROM lnticket.form WHERE id = ?", (form_id,))
|