From 3ce1008db672982ea3ab45328f844e1b9f4df94d Mon Sep 17 00:00:00 2001 From: Peder Bergebakken Sundt Date: Sun, 4 Mar 2018 15:25:19 +0100 Subject: [PATCH] Add api.playlist_move --- grzegorz/api.py | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/grzegorz/api.py b/grzegorz/api.py index b1e8b50..de55a63 100644 --- a/grzegorz/api.py +++ b/grzegorz/api.py @@ -168,10 +168,25 @@ async def playlist_remove_or_clear(request, mpv_control): action = "clear all" return locals() -#@bp.get("/something") +@bp.post("/playlist/move") +@doc.summary("Move playlist item to new position") +@doc.description( + "Move the playlist entry at index1, so that it takes the " + "place of the entry index2. (Paradoxically, the moved playlist " + "entry will not have the index value index2 after moving if index1 " + "was lower than index2, because index2 refers to the target entry, " + "not the index the entry will have after moving.)") +@doc.consumes({"index2": int}, required=True) +@doc.consumes({"index1": int}, required=True) @response_json -async def noe(request, mpv_control): - value = await mpv_control.playlist_move(index1, index2) +async def playlist_move(request, mpv_control): + if "index1" not in request.args or "index2" not in request.args: + raise APIError( + "Missing at least one of the required query " + "parameters: \"index1\" and \"index2\"") + success = await mpv_control.playlist_move( + int(request.args["index1"][0]), + int(request.args["index2"][0])) return locals() #@bp.get("/something")