2018-07-12 18:46:02 +02:00
|
|
|
#!/usr/bin/env python
|
2017-05-17 10:09:50 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
2018-07-12 18:46:02 +02:00
|
|
|
from __future__ import absolute_import, division, unicode_literals
|
2017-05-17 10:09:50 +02:00
|
|
|
import logging
|
|
|
|
from threading import Thread
|
|
|
|
from xbmc import sleep
|
|
|
|
|
2018-06-21 19:24:37 +02:00
|
|
|
from . import utils
|
|
|
|
from . import state
|
2017-05-17 10:09:50 +02:00
|
|
|
|
|
|
|
###############################################################################
|
2018-06-21 19:24:37 +02:00
|
|
|
LOG = logging.getLogger('PLEX.command_pipeline')
|
2017-05-17 10:09:50 +02:00
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
|
2018-06-21 19:24:37 +02:00
|
|
|
@utils.thread_methods
|
2017-05-17 10:09:50 +02:00
|
|
|
class Monitor_Window(Thread):
|
|
|
|
"""
|
|
|
|
Monitors window('plex_command') for new entries that we need to take care
|
|
|
|
of, e.g. for new plays initiated on the Kodi side with addon paths.
|
|
|
|
|
|
|
|
Adjusts state.py accordingly
|
|
|
|
"""
|
|
|
|
def run(self):
|
2018-02-11 14:57:39 +01:00
|
|
|
stopped = self.stopped
|
2018-01-06 15:19:12 +01:00
|
|
|
queue = state.COMMAND_PIPELINE_QUEUE
|
|
|
|
LOG.info("----===## Starting Kodi_Play_Client ##===----")
|
2018-02-11 14:57:39 +01:00
|
|
|
while not stopped():
|
2018-06-21 19:24:37 +02:00
|
|
|
if utils.window('plex_command'):
|
|
|
|
value = utils.window('plex_command')
|
|
|
|
utils.window('plex_command', clear=True)
|
2017-08-21 18:59:47 +02:00
|
|
|
if value.startswith('PLAY-'):
|
|
|
|
queue.put(value.replace('PLAY-', ''))
|
2017-05-17 10:09:50 +02:00
|
|
|
elif value == 'SUSPEND_LIBRARY_THREAD-True':
|
|
|
|
state.SUSPEND_LIBRARY_THREAD = True
|
|
|
|
elif value == 'SUSPEND_LIBRARY_THREAD-False':
|
|
|
|
state.SUSPEND_LIBRARY_THREAD = False
|
|
|
|
elif value == 'STOP_SYNC-True':
|
|
|
|
state.STOP_SYNC = True
|
|
|
|
elif value == 'STOP_SYNC-False':
|
|
|
|
state.STOP_SYNC = False
|
|
|
|
elif value == 'PMS_STATUS-Auth':
|
|
|
|
state.PMS_STATUS = 'Auth'
|
|
|
|
elif value == 'PMS_STATUS-401':
|
|
|
|
state.PMS_STATUS = '401'
|
|
|
|
elif value == 'SUSPEND_USER_CLIENT-True':
|
|
|
|
state.SUSPEND_USER_CLIENT = True
|
|
|
|
elif value == 'SUSPEND_USER_CLIENT-False':
|
|
|
|
state.SUSPEND_USER_CLIENT = False
|
|
|
|
elif value.startswith('PLEX_TOKEN-'):
|
|
|
|
state.PLEX_TOKEN = value.replace('PLEX_TOKEN-', '') or None
|
2017-05-17 16:14:17 +02:00
|
|
|
elif value.startswith('PLEX_USERNAME-'):
|
|
|
|
state.PLEX_USERNAME = \
|
|
|
|
value.replace('PLEX_USERNAME-', '') or None
|
2017-08-21 18:53:38 +02:00
|
|
|
elif value.startswith('RUN_LIB_SCAN-'):
|
|
|
|
state.RUN_LIB_SCAN = value.replace('RUN_LIB_SCAN-', '')
|
2018-02-15 19:47:01 +01:00
|
|
|
elif value.startswith('CONTEXT_menu?'):
|
|
|
|
queue.put('dummy?mode=context_menu&%s'
|
|
|
|
% value.replace('CONTEXT_menu?', ''))
|
2018-03-22 18:51:11 +01:00
|
|
|
elif value.startswith('NAVIGATE'):
|
|
|
|
queue.put(value.replace('NAVIGATE-', ''))
|
2017-05-17 16:14:17 +02:00
|
|
|
else:
|
|
|
|
raise NotImplementedError('%s not implemented' % value)
|
2017-05-17 10:09:50 +02:00
|
|
|
else:
|
|
|
|
sleep(50)
|
|
|
|
# Put one last item into the queue to let playback_starter end
|
|
|
|
queue.put(None)
|
2018-01-06 15:19:12 +01:00
|
|
|
LOG.info("----===## Kodi_Play_Client stopped ##===----")
|