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

112 lines
3.5 KiB
Python
Raw Normal View History

2021-10-10 16:23:39 +01:00
from typing import List, Optional
from . import db
2021-10-12 19:47:01 +01:00
from .models import Jukebox, JukeboxPayment, CreateJukeLinkData, CreateJukeboxPayment
2021-10-10 16:23:39 +01:00
from lnbits.helpers import urlsafe_short_hash
async def create_jukebox(
2021-10-17 18:33:29 +01:00
data: CreateJukeLinkData, inkey: Optional[str] = ""
2021-10-10 16:23:39 +01:00
) -> Jukebox:
juke_id = urlsafe_short_hash()
result = await db.execute(
"""
INSERT INTO jukebox.jukebox (id, user, title, wallet, sp_user, sp_secret, sp_access_token, sp_refresh_token, sp_device, sp_playlists, price, profit)
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
""",
(
juke_id,
2021-10-12 18:54:40 +01:00
data.user,
data.title,
data.wallet,
data.sp_user,
data.sp_secret,
data.sp_access_token,
data.sp_refresh_token,
data.sp_device,
data.sp_playlists,
data.price,
2021-10-10 16:23:39 +01:00
0,
),
)
jukebox = await get_jukebox(juke_id)
assert jukebox, "Newly created Jukebox couldn't be retrieved"
return jukebox
2021-10-12 18:54:40 +01:00
async def update_jukebox(
data: CreateJukeLinkData, juke_id: Optional[str] = ""
) -> Optional[Jukebox]:
q = ", ".join([f"{field[0]} = ?" for field in data])
items = [f"{field[1]}" for field in data]
items.append(juke_id)
print(q)
print(items)
await db.execute(f"UPDATE jukebox.jukebox SET {q} WHERE id = ?", (items))
2021-10-10 16:23:39 +01:00
row = await db.fetchone("SELECT * FROM jukebox.jukebox WHERE id = ?", (juke_id,))
return Jukebox(**row) if row else None
async def get_jukebox(juke_id: str) -> Optional[Jukebox]:
row = await db.fetchone("SELECT * FROM jukebox.jukebox WHERE id = ?", (juke_id,))
return Jukebox(**row) if row else None
async def get_jukebox_by_user(user: str) -> Optional[Jukebox]:
row = await db.fetchone("SELECT * FROM jukebox.jukebox WHERE sp_user = ?", (user,))
return Jukebox(**row) if row else None
async def get_jukeboxs(user: str) -> List[Jukebox]:
rows = await db.fetchall("SELECT * FROM jukebox.jukebox WHERE user = ?", (user,))
for row in rows:
2021-10-12 18:54:40 +01:00
if row.sp_playlists == None:
print("cunt")
2021-10-10 16:23:39 +01:00
await delete_jukebox(row.id)
rows = await db.fetchall("SELECT * FROM jukebox.jukebox WHERE user = ?", (user,))
2021-10-12 18:54:40 +01:00
return [Jukebox(**row) for row in rows]
2021-10-10 16:23:39 +01:00
async def delete_jukebox(juke_id: str):
await db.execute(
"""
DELETE FROM jukebox.jukebox WHERE id = ?
""",
(juke_id),
)
#####################################PAYMENTS
2021-10-12 19:47:01 +01:00
async def create_jukebox_payment(data: CreateJukeboxPayment) -> JukeboxPayment:
2021-10-10 16:23:39 +01:00
result = await db.execute(
"""
INSERT INTO jukebox.jukebox_payment (payment_hash, juke_id, song_id, paid)
VALUES (?, ?, ?, ?)
""",
2021-10-17 18:33:29 +01:00
(data.payment_hash, data.juke_id, data.song_id, False),
2021-10-10 16:23:39 +01:00
)
2021-10-12 19:47:01 +01:00
jukebox_payment = await get_jukebox_payment(data.payment_hash)
2021-10-10 16:23:39 +01:00
assert jukebox_payment, "Newly created Jukebox Payment couldn't be retrieved"
return jukebox_payment
async def update_jukebox_payment(
payment_hash: str, **kwargs
) -> Optional[JukeboxPayment]:
q = ", ".join([f"{field[0]} = ?" for field in kwargs.items()])
await db.execute(
f"UPDATE jukebox.jukebox_payment SET {q} WHERE payment_hash = ?",
(*kwargs.values(), payment_hash),
)
return await get_jukebox_payment(payment_hash)
async def get_jukebox_payment(payment_hash: str) -> Optional[JukeboxPayment]:
row = await db.fetchone(
"SELECT * FROM jukebox.jukebox_payment WHERE payment_hash = ?", (payment_hash,)
)
return JukeboxPayment(**row) if row else None