mirror of
https://github.com/jellyfin/jellyfin-kodi.git
synced 2025-05-08 02:15:08 +00:00
Fix webservice being stalled
This time, it should work. Logging was causing the stall?!
This commit is contained in:
parent
c367deed4a
commit
0e30a28dcb
164 changed files with 116 additions and 42857 deletions
|
@ -2,13 +2,13 @@
|
|||
|
||||
#################################################################################################
|
||||
|
||||
import BaseHTTPServer
|
||||
import logging
|
||||
import httplib
|
||||
import threading
|
||||
import urlparse
|
||||
|
||||
import xbmc
|
||||
import xbmcvfs
|
||||
|
||||
import cherrypy
|
||||
|
||||
#################################################################################################
|
||||
|
||||
|
@ -17,60 +17,125 @@ LOG = logging.getLogger("EMBY."+__name__)
|
|||
|
||||
#################################################################################################
|
||||
|
||||
|
||||
class Root(object):
|
||||
|
||||
@cherrypy.expose
|
||||
def default(self, *args, **kwargs):
|
||||
|
||||
try:
|
||||
if not kwargs.get('Id').isdigit():
|
||||
raise IndexError("Incorrect Id format: %s" % kwargs.get('Id'))
|
||||
|
||||
LOG.info("Webservice called with params: %s", kwargs)
|
||||
|
||||
return ("plugin://plugin.video.emby?mode=play&id=%s&dbid=%s&filename=%s&transcode=%s"
|
||||
% (kwargs.get('Id'), kwargs.get('KodiId'), kwargs.get('Name'), kwargs.get('transcode') or False))
|
||||
|
||||
except IndexError as error:
|
||||
LOG.error(error)
|
||||
|
||||
raise cherrypy.HTTPError(404, error)
|
||||
|
||||
except Exception as error:
|
||||
LOG.exception(error)
|
||||
|
||||
raise cherrypy.HTTPError(500, "Exception occurred: %s" % error)
|
||||
|
||||
class WebService(threading.Thread):
|
||||
|
||||
root = None
|
||||
''' Run a webservice to trigger playback.
|
||||
'''
|
||||
stop_thread = False
|
||||
|
||||
def __init__(self):
|
||||
|
||||
self.root = Root()
|
||||
cherrypy.config.update({
|
||||
'engine.autoreload.on' : False,
|
||||
'log.screen': False,
|
||||
'engine.timeout_monitor.frequency': 5,
|
||||
'server.shutdown_timeout': 1,
|
||||
})
|
||||
threading.Thread.__init__(self)
|
||||
|
||||
def run(self):
|
||||
|
||||
LOG.info("--->[ webservice/%s ]", PORT)
|
||||
conf = {
|
||||
'global': {
|
||||
'server.socket_host': '0.0.0.0',
|
||||
'server.socket_port': PORT
|
||||
}, '/': {}
|
||||
}
|
||||
cherrypy.quickstart(self.root, '/', conf)
|
||||
|
||||
def stop(self):
|
||||
|
||||
cherrypy.engine.exit()
|
||||
self.join(0)
|
||||
''' Called when the thread needs to stop
|
||||
'''
|
||||
try:
|
||||
conn = httplib.HTTPConnection("127.0.0.1:%d" % PORT)
|
||||
conn.request("QUIT", "/")
|
||||
conn.getresponse()
|
||||
self.stop_thread = True
|
||||
except Exception as error:
|
||||
pass
|
||||
|
||||
def run(self):
|
||||
|
||||
''' Called to start the webservice.
|
||||
'''
|
||||
LOG.info("--->[ webservice/%s ]", PORT)
|
||||
|
||||
try:
|
||||
server = HttpServer(('127.0.0.1', PORT), requestHandler)
|
||||
server.serve_forever()
|
||||
except Exception as error:
|
||||
|
||||
if '10053' not in error: # ignore host diconnected errors
|
||||
LOG.exception(error)
|
||||
|
||||
LOG.info("---<[ webservice ]")
|
||||
|
||||
|
||||
class HttpServer(BaseHTTPServer.HTTPServer):
|
||||
|
||||
''' Http server that reacts to self.stop flag.
|
||||
'''
|
||||
def serve_forever(self):
|
||||
|
||||
''' Handle one request at a time until stopped.
|
||||
'''
|
||||
self.stop = False
|
||||
|
||||
while not self.stop:
|
||||
self.handle_request()
|
||||
|
||||
|
||||
class requestHandler(BaseHTTPServer.BaseHTTPRequestHandler):
|
||||
|
||||
#Handler for the GET requests
|
||||
|
||||
def log_message(self, format, *args):
|
||||
|
||||
''' Mute the webservice requests.
|
||||
'''
|
||||
pass
|
||||
|
||||
def get_params(self):
|
||||
|
||||
''' Get the params
|
||||
'''
|
||||
try:
|
||||
path = self.path[1:]
|
||||
|
||||
if '?' in path:
|
||||
path = path.split('?', 1)[1]
|
||||
|
||||
params = dict(urlparse.parse_qsl(path))
|
||||
except Exception:
|
||||
params = {}
|
||||
|
||||
return params
|
||||
|
||||
def do_HEAD(self):
|
||||
|
||||
''' Called on HEAD requests
|
||||
'''
|
||||
self.send_response(200)
|
||||
self.end_headers()
|
||||
|
||||
return
|
||||
|
||||
def do_GET(self):
|
||||
|
||||
''' Return plugin path
|
||||
'''
|
||||
try:
|
||||
params = self.get_params()
|
||||
|
||||
if not params:
|
||||
raise IndexError("Incomplete URL format")
|
||||
|
||||
if not params.get('Id').isdigit():
|
||||
raise IndexError("Incorrect Id format %s" % params.get('Id'))
|
||||
|
||||
xbmc.log("[ webservice ] path: %s params: %s" % (str(self.path), str(params)), xbmc.LOGWARNING)
|
||||
|
||||
path = ("plugin://plugin.video.emby?mode=play&id=%s&dbid=%s&filename=%s&transcode=%s"
|
||||
% (params.get('Id'), params.get('KodiId'), params.get('Name'), params.get('transcode') or False))
|
||||
|
||||
self.send_response(200)
|
||||
self.send_header('Content-type','text/html')
|
||||
self.end_headers()
|
||||
self.wfile.write(path)
|
||||
|
||||
except IndexError as error:
|
||||
|
||||
xbmc.log(str(error), xbmc.LOGWARNING)
|
||||
self.send_error(404, "Exception occurred: %s" % error)
|
||||
|
||||
except Exception as error:
|
||||
|
||||
xbmc.log(str(error), xbmc.LOGWARNING)
|
||||
self.send_error(500, "Exception occurred: %s" % error)
|
||||
|
||||
return
|
||||
|
||||
del self.root
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue