lnbits-legend/lnbits/extensions/livestream/views_api.py

145 lines
4.2 KiB
Python
Raw Normal View History

from quart import g, jsonify
from http import HTTPStatus
from lnurl.exceptions import InvalidUrl as LnurlInvalidUrl # type: ignore
from lnbits.decorators import api_check_wallet_key, api_validate_post_request
2021-08-23 10:18:52 +01:00
from fastapi import FastAPI, Query
from fastapi.encoders import jsonable_encoder
from fastapi.responses import JSONResponse
from pydantic import BaseModel
from . import livestream_ext
from .crud import (
get_or_create_livestream_by_wallet,
add_track,
get_tracks,
update_track,
add_producer,
get_producers,
update_current_track,
update_livestream_fee,
delete_track_from_livestream,
)
2021-08-23 10:18:52 +01:00
@livestream_ext.get("/api/v1/livestream")
@api_check_wallet_key("invoice")
async def api_livestream_from_wallet():
ls = await get_or_create_livestream_by_wallet(g.wallet.id)
tracks = await get_tracks(ls.id)
producers = await get_producers(ls.id)
try:
2021-08-23 10:18:52 +01:00
return
{
**ls._asdict(),
**{
"lnurl": ls.lnurl,
"tracks": [
dict(lnurl=track.lnurl, **track._asdict())
for track in tracks
],
"producers": [producer._asdict() for producer in producers],
},
}
2021-08-23 10:18:52 +01:00
,
HTTPStatus.OK
except LnurlInvalidUrl:
2021-08-23 10:18:52 +01:00
return
{
"message": "LNURLs need to be delivered over a publically accessible `https` domain or Tor."
}
2021-08-23 10:18:52 +01:00
,
HTTPStatus.UPGRADE_REQUIRED
2021-08-23 10:18:52 +01:00
@livestream_ext.put("/api/v1/livestream/track/{track_id}")
@api_check_wallet_key("invoice")
async def api_update_track(track_id):
try:
id = int(track_id)
except ValueError:
id = 0
if id <= 0:
id = None
ls = await get_or_create_livestream_by_wallet(g.wallet.id)
await update_current_track(ls.id, id)
return "", HTTPStatus.NO_CONTENT
2021-08-23 10:18:52 +01:00
@livestream_ext.put("/api/v1/livestream/fee/{fee_pct}")
@api_check_wallet_key("invoice")
async def api_update_fee(fee_pct):
ls = await get_or_create_livestream_by_wallet(g.wallet.id)
await update_livestream_fee(ls.id, int(fee_pct))
return "", HTTPStatus.NO_CONTENT
2021-08-23 10:18:52 +01:00
class CreateData(BaseModel):
name: str
download_url: str = Query(None)
price_msat: int = Query(None, ge=0)
producer_id: int #missing the exclude thing
producer_name: str #missing the exclude thing
@livestream_ext.post("/api/v1/livestream/tracks")
@livestream_ext.put("/api/v1/livestream/tracks/{id}")
@api_check_wallet_key("invoice")
2021-08-23 10:18:52 +01:00
# @api_validate_post_request(
# schema={
# "name": {"type": "string", "empty": False, "required": True},
# "download_url": {"type": "string", "empty": False, "required": False},
# "price_msat": {"type": "number", "min": 0, "required": False},
# "producer_id": {
# "type": "number",
# "required": True,
# "excludes": "producer_name",
# },
# "producer_name": {
# "type": "string",
# "required": True,
# "excludes": "producer_id",
# },
# }
# )
async def api_add_track(data: CreateData, id=None):
ls = await get_or_create_livestream_by_wallet(g.wallet.id)
2021-08-23 10:18:52 +01:00
if "producer_id" in data:
p_id = data["producer_id"]
elif "producer_name" in data:
p_id = await add_producer(ls.id, data["producer_name"])
else:
raise TypeError("need either producer_id or producer_name arguments")
if id:
await update_track(
ls.id,
id,
2021-08-23 10:18:52 +01:00
data["name"],
data.get("download_url"),
data.get("price_msat", 0),
p_id,
)
return "", HTTPStatus.OK
else:
await add_track(
ls.id,
2021-08-23 10:18:52 +01:00
data["name"],
data.get("download_url"),
data.get("price_msat", 0),
p_id,
)
return "", HTTPStatus.CREATED
2021-08-23 10:18:52 +01:00
@livestream_ext.delete("/api/v1/livestream/tracks/{track_id}")
@api_check_wallet_key("invoice")
async def api_delete_track(track_id):
ls = await get_or_create_livestream_by_wallet(g.wallet.id)
await delete_track_from_livestream(ls.id, track_id)
return "", HTTPStatus.NO_CONTENT