Add volume control, errorhandling and MPVError exception class

This commit is contained in:
Peder Bergebakken Sundt 2018-02-24 23:17:05 +01:00
parent 7f6b9fcba9
commit 226e807f24
2 changed files with 62 additions and 46 deletions

View File

@ -3,20 +3,27 @@ import asyncio
from . import mpv from . import mpv
bp = Blueprint("grzegorz-api") bp = Blueprint("grzegorz-api")
#this blueprint assumes a mpv.MPVControl instance is available at request.app.config["mpv_control"] # this blueprint assumes a mpv.MPVControl instance is available
# at request.app.config["mpv_control"]
#route decorators: #route decorators:
def response_json(func): def response_json(func):
async def newfunc(*args, **kwargs): async def newfunc(*args, **kwargs):
#try: try:
body = await func(*args, **kwargs) mpv_control = args[0].app.config["mpv_control"]
body = await func(*args, mpv_control, **kwargs)
if "error" not in body: if "error" not in body:
body["error"] = False body["error"] = False
if "request" in body: if "request" in body:
del body["request"] del body["request"]
if "mpv_control" in body:
del body["mpv_control"]
return response.json(body) return response.json(body)
#except Exception as e: except Exception as e:
# return response.json({"error": e.__class__.__name__, "error_msg": e.args}) return response.json({
"error": e.__class__.__name__,
"errortext": str(e)
})
return newfunc return newfunc
def response_text(func): def response_text(func):
async def newfunc(*args, **kwargs): async def newfunc(*args, **kwargs):
@ -32,99 +39,102 @@ async def root(request):
@bp.post("/load") @bp.post("/load")
@response_json @response_json
async def loadfile(request): async def loadfile(request, mpv_control):
if "source" not in request.json: if "source" not in request.json:
return {"error", "no param \"source\""} return {"error", "no param \"source\""}
success = await request.app.config["mpv_control"].loadfile(request.json["source"]) success = await mpv_control.loadfile(request.json["source"])
return locals() return locals()
@bp.get("/play") @bp.get("/play")
@response_json @response_json
async def get_play(request): async def get_play(request, mpv_control):
value = await request.app.config["mpv_control"].pause_get() == False value = await mpv_control.pause_get() == False
return locals() return locals()
@bp.post("/play") @bp.post("/play")
@response_json @response_json
async def set_play(request): async def set_play(request, mpv_control):
success = await request.app.config["mpv_control"] \ success = await request.app.config["mpv_control"] \
.pause_set(request.form["play"][0] not in ["true", "1"]) .pause_set(request.form["play"][0] not in ["true", "1"])
return locals() return locals()
@bp.get("/volume")
@response_json
async def get_volume(request, mpv_control):
value = await mpv_control.volume_get()
return locals()
@bp.post("/volume")
@response_json
async def set_volume(request, mpv_control):
success = await request.app.config["mpv_control"] \
.volume_set(int(request.form["volume"][0]))
return locals()
#@bp.get("/something") #@bp.get("/something")
@response_json @response_json
async def noe(request): async def noe(request, mpv_control):
body = await request.app.config["mpv_control"].volume_get() body = await mpv_control.time_pos_get()
return body return body
#@bp.get("/something") #@bp.get("/something")
@response_json @response_json
async def noe(request): async def noe(request, mpv_control):
body = await request.app.config["mpv_control"].volume_set(volume) body = await mpv_control.time_remaining_get()
return body return body
#@bp.get("/something") #@bp.get("/something")
@response_json @response_json
async def noe(request): async def noe(request, mpv_control):
body = await request.app.config["mpv_control"].time_pos_get() body = await mpv_control.seek_relative(seconds)
return body return body
#@bp.get("/something") #@bp.get("/something")
@response_json @response_json
async def noe(request): async def noe(request, mpv_control):
body = await request.app.config["mpv_control"].time_remaining_get() body = await mpv_control.seek_percent(percent)
return body
#@bp.get("/something")
@response_json
async def noe(request):
body = await request.app.config["mpv_control"].seek_relative(seconds)
return body
#@bp.get("/something")
@response_json
async def noe(request):
body = await request.app.config["mpv_control"].seek_percent(percent)
return body return body
@bp.get("/playlist") @bp.get("/playlist")
@response_json @response_json
async def noe(request): async def noe(request, mpv_control):
value = await request.app.config["mpv_control"].playlist_get() value = await mpv_control.playlist_get()
for i, v in enumerate(value):
pass
return locals() return locals()
@bp.post("/playlist/next") @bp.post("/playlist/next")
@response_json @response_json
async def noe(request): async def noe(request, mpv_control):
success = await request.app.config["mpv_control"].playlist_next() success = await mpv_control.playlist_next()
return locals() return locals()
@bp.post("/playlist/previous") @bp.post("/playlist/previous")
@response_json @response_json
async def noe(request): async def noe(request, mpv_control):
success = await request.app.config["mpv_control"].playlist_prev() success = await mpv_control.playlist_prev()
return locals() return locals()
#@bp.get("/something") #@bp.get("/something")
@response_json @response_json
async def noe(request): async def noe(request, mpv_control):
body = await request.app.config["mpv_control"].playlist_clear() body = await mpv_control.playlist_clear()
return body return body
#@bp.get("/something") #@bp.get("/something")
@response_json @response_json
async def noe(request): async def noe(request, mpv_control):
body = await request.app.config["mpv_control"].playlist_remove(index=None) body = await mpv_control.playlist_remove(index=None)
return body return body
#@bp.get("/something") #@bp.get("/something")
@response_json @response_json
async def noe(request): async def noe(request, mpv_control):
body = await request.app.config["mpv_control"].playlist_move(index1, index2) body = await mpv_control.playlist_move(index1, index2)
return body return body
#@bp.get("/something") #@bp.get("/something")
@response_json @response_json
async def noe(request): async def noe(request, mpv_control):
body = await request.app.config["mpv_control"].playlist_shuffle() body = await mpv_control.playlist_shuffle()
return body return body

View File

@ -67,6 +67,8 @@ class MPV:
else: # response else: # response
self.responses.put_nowait(msg) self.responses.put_nowait(msg)
class MPVError(Exception): pass
class MPVControl: class MPVControl:
def __init__(self): def __init__(self):
self.mpv = MPV() self.mpv = MPV()
@ -101,9 +103,13 @@ class MPVControl:
resp = await self.send_request({"command":["set_property", "pause", bool(state)]}) resp = await self.send_request({"command":["set_property", "pause", bool(state)]})
return resp["error"] == "success" return resp["error"] == "success"
async def volume_get(self): async def volume_get(self):
return await self.send_request({"command":["get_property", "volume"]}) resp = await self.send_request({"command":["get_property", "volume"]})
if "error" in resp and resp["error"] != "success" or 1:
raise MPVError("Unable to set volume!")
return resp["data"] if "data" in resp else None
async def volume_set(self, volume): async def volume_set(self, volume):
return await self.send_request({"command":["set_property", "volume", volume]}) resp = await self.send_request({"command":["set_property", "volume", volume]})
return resp["error"] == "success"
async def time_pos_get(self): async def time_pos_get(self):
return await self.send_request({"command":["get_property", "time-pos"]}) return await self.send_request({"command":["get_property", "time-pos"]})
async def time_remaining_get(self): async def time_remaining_get(self):