Improvements to Plex Companion daemon

- Still need improvements to tell the PMS and Plex Companion devices
that we STOPPED playing something.
This commit is contained in:
tomkat83 2016-08-07 20:52:49 +02:00
parent a248580f24
commit caba11c43f
3 changed files with 21 additions and 10 deletions

View file

@ -3,6 +3,7 @@ import threading
import traceback import traceback
import socket import socket
import Queue import Queue
import threading
import xbmc import xbmc
@ -164,6 +165,9 @@ class PlexCompanion(threading.Thread):
client.start_all() client.start_all()
message_count = 0 message_count = 0
if httpd:
t = threading.Thread(target=httpd.handle_request)
while not threadStopped(): while not threadStopped():
# If we are not authorized, sleep # If we are not authorized, sleep
# Otherwise, we trigger a download which leads to a # Otherwise, we trigger a download which leads to a
@ -173,23 +177,27 @@ class PlexCompanion(threading.Thread):
break break
xbmc.sleep(1000) xbmc.sleep(1000)
try: try:
if httpd:
httpd.handle_request()
message_count += 1 message_count += 1
if httpd:
if not t.isAlive():
t = threading.Thread(target=httpd.handle_request)
t.start()
if message_count > 100: if message_count == 3000:
message_count = 0
if client.check_client_registration(): if client.check_client_registration():
log("Client is still registered", 1) log("Client is still registered", 1)
else: else:
log("Client is no longer registered", 1) log("Client is no longer registered", 1)
log("Plex Companion still running on port %s" log("Plex Companion still running on port %s"
% self.settings['myport'], 1) % self.settings['myport'], 1)
message_count = 0
# Get and set servers # Get and set servers
if message_count % 30 == 0:
subscriptionManager.serverlist = client.getServerList() subscriptionManager.serverlist = client.getServerList()
subscriptionManager.notify() subscriptionManager.notify()
if not httpd:
message_count = 0
except: except:
log("Error in loop, continuing anyway. Traceback:", 1) log("Error in loop, continuing anyway. Traceback:", 1)
log(traceback.format_exc(), 1) log(traceback.format_exc(), 1)
@ -202,7 +210,9 @@ class PlexCompanion(threading.Thread):
# Got instructions, process them # Got instructions, process them
self.processTasks(task) self.processTasks(task)
queue.task_done() queue.task_done()
xbmc.sleep(10) # Don't sleep
continue
xbmc.sleep(20)
client.stop_all() client.stop_all()
if httpd: if httpd:

View file

@ -192,15 +192,18 @@ class MyHandler(BaseHTTPRequestHandler):
for playerid in js.getPlayerIds(): for playerid in js.getPlayerIds():
js.jsonrpc("Player.PlayPause", js.jsonrpc("Player.PlayPause",
{"playerid": playerid, "play": True}) {"playerid": playerid, "play": True})
subMgr.notify()
elif request_path == "player/playback/pause": elif request_path == "player/playback/pause":
self.response(getOKMsg(), js.getPlexHeaders()) self.response(getOKMsg(), js.getPlexHeaders())
for playerid in js.getPlayerIds(): for playerid in js.getPlayerIds():
js.jsonrpc("Player.PlayPause", js.jsonrpc("Player.PlayPause",
{"playerid": playerid, "play": False}) {"playerid": playerid, "play": False})
subMgr.notify()
elif request_path == "player/playback/stop": elif request_path == "player/playback/stop":
self.response(getOKMsg(), js.getPlexHeaders()) self.response(getOKMsg(), js.getPlexHeaders())
for playerid in js.getPlayerIds(): for playerid in js.getPlayerIds():
js.jsonrpc("Player.Stop", {"playerid": playerid}) js.jsonrpc("Player.Stop", {"playerid": playerid})
subMgr.notify()
elif request_path == "player/playback/seekTo": elif request_path == "player/playback/seekTo":
self.response(getOKMsg(), js.getPlexHeaders()) self.response(getOKMsg(), js.getPlexHeaders())
for playerid in js.getPlayerIds(): for playerid in js.getPlayerIds():

View file

@ -150,8 +150,6 @@ class SubscriptionManager:
return True return True
def notifyServer(self, players): def notifyServer(self, players):
if not players:
return True
for p in players.values(): for p in players.values():
info = self.playerprops[p.get('playerid')] info = self.playerprops[p.get('playerid')]
params = {'state': 'stopped'} params = {'state': 'stopped'}