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

122 lines
3.5 KiB
Python
Raw Normal View History

2020-05-08 21:03:18 +01:00
from typing import List, Optional, Union
from lnbits.db import open_ext_db
from lnbits.helpers import urlsafe_short_hash
from .models import Tickets, Forms
#######TICKETS########
2020-08-30 23:19:43 -03:00
def create_ticket(checking_id: str, wallet: str, form: str, name: str, email: str, ltext: str, sats: int) -> Tickets:
2020-08-10 19:06:56 +01:00
with open_ext_db("lnticket") as db:
db.execute(
"""
2020-08-13 23:43:42 +01:00
INSERT INTO ticket (id, form, email, ltext, name, wallet, sats, paid)
2020-08-10 19:06:56 +01:00
VALUES (?, ?, ?, ?, ?, ?, ?, ?)
""",
2020-08-13 23:43:42 +01:00
(checking_id, form, email, ltext, name, wallet, sats, False),
2020-08-10 19:06:56 +01:00
)
return get_ticket(checking_id)
2020-05-08 21:03:18 +01:00
2020-08-30 23:19:43 -03:00
2020-08-10 19:06:56 +01:00
def update_ticket(paid: bool, checking_id: str) -> Tickets:
2020-05-08 21:03:18 +01:00
with open_ext_db("lnticket") as db:
2020-08-13 21:49:50 +01:00
row = db.fetchone("SELECT * FROM ticket WHERE id = ?", (checking_id,))
2020-08-13 23:43:42 +01:00
if row[7] == True:
2020-08-10 19:06:56 +01:00
return get_ticket(checking_id)
2020-05-08 21:03:18 +01:00
db.execute(
"""
2020-08-13 21:49:50 +01:00
UPDATE ticket
2020-08-10 19:06:56 +01:00
SET paid = ?
WHERE id = ?
2020-05-08 21:03:18 +01:00
""",
2020-08-10 19:06:56 +01:00
(paid, checking_id),
2020-05-08 21:03:18 +01:00
)
2020-08-30 23:19:43 -03:00
2020-08-13 23:43:42 +01:00
formdata = get_form(row[1])
2020-08-10 19:06:56 +01:00
amount = formdata.amountmade + row[7]
2020-05-08 21:03:18 +01:00
db.execute(
"""
UPDATE forms
SET amountmade = ?
WHERE id = ?
""",
2020-08-13 23:43:42 +01:00
(amount, row[1]),
2020-05-08 21:03:18 +01:00
)
2020-08-10 19:06:56 +01:00
return get_ticket(checking_id)
2020-05-08 21:03:18 +01:00
2020-08-30 23:19:43 -03:00
2020-05-08 21:03:18 +01:00
def get_ticket(ticket_id: str) -> Optional[Tickets]:
with open_ext_db("lnticket") as db:
2020-08-13 21:49:50 +01:00
row = db.fetchone("SELECT * FROM ticket WHERE id = ?", (ticket_id,))
2020-05-08 21:03:18 +01:00
return Tickets(**row) if row else None
def get_tickets(wallet_ids: Union[str, List[str]]) -> List[Tickets]:
if isinstance(wallet_ids, str):
wallet_ids = [wallet_ids]
with open_ext_db("lnticket") as db:
q = ",".join(["?"] * len(wallet_ids))
2020-08-13 21:49:50 +01:00
rows = db.fetchall(f"SELECT * FROM ticket WHERE wallet IN ({q})", (*wallet_ids,))
2020-05-08 21:03:18 +01:00
return [Tickets(**row) for row in rows]
def delete_ticket(ticket_id: str) -> None:
with open_ext_db("lnticket") as db:
2020-08-13 21:49:50 +01:00
db.execute("DELETE FROM ticket WHERE id = ?", (ticket_id,))
2020-05-08 21:03:18 +01:00
########FORMS#########
def create_form(*, wallet: str, name: str, description: str, costpword: int) -> Forms:
with open_ext_db("lnticket") as db:
form_id = urlsafe_short_hash()
db.execute(
"""
INSERT INTO forms (id, wallet, name, description, costpword, amountmade)
VALUES (?, ?, ?, ?, ?, ?)
""",
2020-08-30 23:19:43 -03:00
(form_id, wallet, name, description, costpword, 0),
2020-05-08 21:03:18 +01:00
)
return get_form(form_id)
2020-08-30 23:19:43 -03:00
2020-05-08 21:03:18 +01:00
def update_form(form_id: str, **kwargs) -> Forms:
q = ", ".join([f"{field[0]} = ?" for field in kwargs.items()])
with open_ext_db("lnticket") as db:
db.execute(f"UPDATE forms SET {q} WHERE id = ?", (*kwargs.values(), form_id))
row = db.fetchone("SELECT * FROM forms WHERE id = ?", (form_id,))
return Forms(**row) if row else None
def get_form(form_id: str) -> Optional[Forms]:
with open_ext_db("lnticket") as db:
row = db.fetchone("SELECT * FROM forms WHERE id = ?", (form_id,))
return Forms(**row) if row else None
def get_forms(wallet_ids: Union[str, List[str]]) -> List[Forms]:
if isinstance(wallet_ids, str):
wallet_ids = [wallet_ids]
with open_ext_db("lnticket") as db:
q = ",".join(["?"] * len(wallet_ids))
rows = db.fetchall(f"SELECT * FROM forms WHERE wallet IN ({q})", (*wallet_ids,))
return [Forms(**row) for row in rows]
def delete_form(form_id: str) -> None:
with open_ext_db("lnticket") as db:
2020-08-30 23:19:43 -03:00
db.execute("DELETE FROM forms WHERE id = ?", (form_id,))