From 719956157306d54b510e97f1cbec2d099a7f1908 Mon Sep 17 00:00:00 2001 From: tomkat83 Date: Thu, 2 Jun 2016 21:12:56 +0200 Subject: [PATCH] Only tell PMS we're connected to what we're playing - Fixes #43 --- resources/lib/plexbmchelper/plexgdm.py | 133 ++++--------------------- 1 file changed, 21 insertions(+), 112 deletions(-) diff --git a/resources/lib/plexbmchelper/plexgdm.py b/resources/lib/plexbmchelper/plexgdm.py index f62921f2..ecf108ae 100644 --- a/resources/lib/plexbmchelper/plexgdm.py +++ b/resources/lib/plexbmchelper/plexgdm.py @@ -215,119 +215,28 @@ class plexgdm: return self.server_list def discover(self): - sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) - - # Set a timeout so the socket does not block indefinitely - sock.settimeout(0.6) - - # Set the time-to-live for messages to 1 for local network - ttl = struct.pack('b', 1) - sock.setsockopt(socket.IPPROTO_IP, socket.IP_MULTICAST_TTL, ttl) - - returnData = [] - try: - # Send data to the multicast group - self.logMsg("Sending discovery messages: %s" - % self.discover_message, 2) - sock.sendto(self.discover_message, self.discover_group) - - # Look for responses from all recipients - while True: - try: - data, server = sock.recvfrom(1024) - self.logMsg("Received data from %s, %s" % server, 2) - returnData.append({'from': server, - 'data': data}) - except socket.timeout: - break - except: - # if we can't send our discovery query, just abort and try again - # on the next loop - return - finally: - sock.close() - - self.discovery_complete = True - - discovered_servers = [] - - if returnData: - - for response in returnData: - update = {'server': response.get('from')[0]} - - # Check if we had a positive HTTP reponse - if "200 OK" in response.get('data'): - for each in response.get('data').split('\r\n'): - update['discovery'] = "auto" - update['owned'] = '1' - update['master'] = 1 - update['role'] = 'master' - update['class'] = None - if "Content-Type:" in each: - update['content-type'] = each.split(':')[1].strip() - elif "Resource-Identifier:" in each: - update['uuid'] = each.split(':')[1].strip() - elif "Name:" in each: - update['serverName'] = each.split(':')[1].strip() - elif "Port:" in each: - update['port'] = each.split(':')[1].strip() - elif "Updated-At:" in each: - update['updated'] = each.split(':')[1].strip() - elif "Version:" in each: - update['version'] = each.split(':')[1].strip() - elif "Server-Class:" in each: - update['class'] = each.split(':')[1].strip() - - # Quickly test if we need https - https = PMSHttpsEnabled( - '%s:%s' % (update['server'], update['port'])) - if https is None: - # Error contacting server - continue - elif https: - update['protocol'] = 'https' - else: - update['protocol'] = 'http' - discovered_servers.append(update) - - # Append REMOTE PMS that we haven't found yet; if necessary currServer = window('pms_server') - if currServer: - currServerProt, currServerIP, currServerPort = \ - currServer.split(':') - currServerIP = currServerIP.replace('/', '') - for server in discovered_servers: - if server['server'] == currServerIP: - break - else: - # Currently active server was not discovered via GDM; ADD - update = { - 'port': currServerPort, - 'protocol': currServerProt, - 'class': None, - 'content-type': 'plex/media-server', - 'discovery': 'auto', - 'master': 1, - 'owned': '1', - 'role': 'master', - 'server': currServerIP, - 'serverName': window('plex_servername'), - 'updated': int(time.time()), - 'uuid': window('plex_machineIdentifier'), - 'version': 'irrelevant' - } - discovered_servers.append(update) - - self.server_list = discovered_servers - - if not self.server_list: - self.logMsg("No servers have been discovered", 0) - else: - self.logMsg("Number of servers Discovered: %s" - % len(self.server_list), 2) - for items in self.server_list: - self.logMsg("Server Discovered: %s" % items, 2) + if not currServer: + return + currServerProt, currServerIP, currServerPort = \ + currServer.split(':') + currServerIP = currServerIP.replace('/', '') + # Currently active server was not discovered via GDM; ADD + self.server_list = [{ + 'port': currServerPort, + 'protocol': currServerProt, + 'class': None, + 'content-type': 'plex/media-server', + 'discovery': 'auto', + 'master': 1, + 'owned': '1', + 'role': 'master', + 'server': currServerIP, + 'serverName': window('plex_servername'), + 'updated': int(time.time()), + 'uuid': window('plex_machineIdentifier'), + 'version': 'irrelevant' + }] def setInterval(self, interval): self.discovery_interval = interval