-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathplex.py
39 lines (32 loc) · 1.44 KB
/
plex.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
import requests
import json
import xml.etree.ElementTree as ET
import logging
import sys
class PlexServer(object):
def __init__(self):
self._logger = logging.getLogger()
try:
with open("./config.json") as w:
self._logger.debug("Loading Plex config.json")
cfg = json.load(w)
self._logger.debug("Plex Config loaded successfully" + str(cfg))
self._url = cfg['plex']['url']
self._token = cfg['plex']['token']
self._interval = cfg['plex']['interval']
except Exception as e:
self._logger.exception("Problem encountered when creating PlexServer object")
sys.exit(1)
def get_interval(self):
return self._interval
def get_active_streams(self):
try:
active_streams = 0
r = requests.get(self._url + "/status/sessions",headers={'X-Plex-Token':self._token})
if(r.status_code == 200):
root = ET.fromstring(r.text)
return len([video.attrib for video in root.iter('Video') for video in video.iter('Player') if video.attrib['state'] == 'playing' or video.attrib['state'] == 'buffering'])
else:
self._logger.error("Did not get expected response from Plex API: %s",r.text)
except Exception as e:
self._logger.exception("Failed to successfully request current active sessions from Plex")