PlexKodiConnect/resources/lib/library_sync/get_metadata.py

60 lines
2 KiB
Python
Raw Normal View History

2017-04-02 17:02:41 +02:00
# -*- coding: utf-8 -*-
from __future__ import absolute_import, division, unicode_literals
2017-04-02 17:02:41 +02:00
from logging import getLogger
2018-10-20 14:49:04 +02:00
from . import common
from .. import plex_functions as PF, backgroundthread, utils
2017-04-02 17:02:41 +02:00
###############################################################################
LOG = getLogger("PLEX." + __name__)
2017-04-02 17:02:41 +02:00
###############################################################################
2018-10-20 14:49:04 +02:00
class GetMetadataTask(backgroundthread.Task, common.libsync_mixin):
2017-04-02 17:02:41 +02:00
"""
Threaded download of Plex XML metadata for a certain library item.
2018-10-20 14:49:04 +02:00
Fills the queue with the downloaded etree XML objects
2017-04-02 17:02:41 +02:00
Input:
2018-10-20 14:49:04 +02:00
queue Queue.Queue() object where this thread will store
2017-04-02 17:02:41 +02:00
the downloaded metadata XMLs as etree objects
"""
2018-10-20 14:49:04 +02:00
def setup(self, queue, plex_id, get_children=False):
2017-04-02 17:02:41 +02:00
self.queue = queue
2018-10-20 14:49:04 +02:00
self.plex_id = plex_id
self.get_children = get_children
2017-04-02 17:02:41 +02:00
def run(self):
"""
Do the work
"""
2018-10-20 14:49:04 +02:00
if self.isCanceled():
return
# Download Metadata
2018-10-25 18:14:35 +02:00
item = {
'xml': PF.GetPlexMetadata(self.plex_id),
'children': None
}
if item['xml'] is None:
2018-10-20 14:49:04 +02:00
# Did not receive a valid XML - skip that item for now
LOG.error("Could not get metadata for %s. Skipping that item "
"for now", self.plex_id)
2018-10-24 17:54:10 +02:00
return
2018-10-25 18:14:35 +02:00
elif item['xml'] == 401:
2018-10-20 14:49:04 +02:00
LOG.error('HTTP 401 returned by PMS. Too much strain? '
'Cancelling sync for now')
utils.window('plex_scancrashed', value='401')
return
if not self.isCanceled() and self.get_children:
children_xml = PF.GetAllPlexChildren(self.plex_id)
2017-04-02 17:02:41 +02:00
try:
2018-10-20 14:49:04 +02:00
children_xml[0].attrib
except (TypeError, IndexError, AttributeError):
LOG.error('Could not get children for Plex id %s',
self.plex_id)
else:
2018-10-25 18:14:35 +02:00
item['children'] = children_xml
self.queue.put(item)