mirror of
https://github.com/jellyfin/jellyfin-kodi.git
synced 2024-11-10 04:06:11 +00:00
Merge pull request #862 from oddstr13/pr-server-plugin-enabled-1
Check for KodiSyncQueue GetPluginSettings endpoint
This commit is contained in:
commit
1dcd4b70c4
3 changed files with 16 additions and 25 deletions
|
@ -1,12 +1,15 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
from __future__ import division, absolute_import, print_function, unicode_literals
|
from __future__ import division, absolute_import, print_function, unicode_literals
|
||||||
|
|
||||||
|
import warnings
|
||||||
|
|
||||||
#################################################################################################
|
#################################################################################################
|
||||||
|
|
||||||
|
|
||||||
class HTTPException(Exception):
|
class HTTPException(Exception):
|
||||||
# Jellyfin HTTP exception
|
# Jellyfin HTTP exception
|
||||||
def __init__(self, status, message):
|
def __init__(self, status, message):
|
||||||
|
warnings.warn(f'{self.__class__.__name__} will be deprecated.', DeprecationWarning, stacklevel=2)
|
||||||
self.status = status
|
self.status = status
|
||||||
self.message = message
|
self.message = message
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ import json
|
||||||
import requests
|
import requests
|
||||||
from six import ensure_str
|
from six import ensure_str
|
||||||
|
|
||||||
|
from ..helper.exceptions import HTTPException
|
||||||
from ..helper.utils import settings
|
from ..helper.utils import settings
|
||||||
from ..helper import LazyLogger
|
from ..helper import LazyLogger
|
||||||
|
|
||||||
|
@ -254,37 +255,24 @@ class API(object):
|
||||||
'ParentId': parent_id
|
'ParentId': parent_id
|
||||||
})
|
})
|
||||||
|
|
||||||
def get_plugins(self):
|
def check_companion_enabled(self):
|
||||||
return self._get("Plugins")
|
|
||||||
|
|
||||||
def check_companion_installed(self):
|
|
||||||
"""
|
"""
|
||||||
|
True = Enabled
|
||||||
|
False = Not enabled
|
||||||
None = Unknown
|
None = Unknown
|
||||||
True = Installed, but possibly not loaded right now
|
|
||||||
False = Not installed, scheduled for uninstalling or disabled
|
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
kodi_sync_queue = [
|
plugin_settings = self._get("Jellyfin.Plugin.KodiSyncQueue/GetPluginSettings") or {}
|
||||||
x
|
return plugin_settings.get('IsEnabled')
|
||||||
for x in self.get_plugins()
|
|
||||||
if x.get("Id") == "771e19d653854cafb35c28a0e865cf63"
|
|
||||||
]
|
|
||||||
|
|
||||||
LOG.debug("KodiSyncQueue Plugins result: %s", kodi_sync_queue)
|
|
||||||
|
|
||||||
kodi_sync_queue_filtered = [
|
|
||||||
x
|
|
||||||
for x in kodi_sync_queue
|
|
||||||
if x.get("Status")
|
|
||||||
in ["Active", "Restart", "Malfunctioned", "NotSupported"]
|
|
||||||
]
|
|
||||||
|
|
||||||
if kodi_sync_queue_filtered:
|
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
except requests.RequestException as e:
|
except requests.RequestException as e:
|
||||||
LOG.warning("Error checking companion installed state: %s", e)
|
LOG.warning("Error checking companion installed state: %s", e)
|
||||||
|
if e.response.status_code == 404:
|
||||||
|
return False
|
||||||
|
except HTTPException as e:
|
||||||
|
LOG.warning("Error checking companion installed state: %s", e)
|
||||||
|
if e.status == 404:
|
||||||
|
return False
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
|
@ -353,7 +353,7 @@ class Library(threading.Thread):
|
||||||
'kodiCompanion.bool'
|
'kodiCompanion.bool'
|
||||||
):
|
):
|
||||||
# None == Unknown
|
# None == Unknown
|
||||||
if self.server.jellyfin.check_companion_installed() is not False:
|
if self.server.jellyfin.check_companion_enabled() is not False:
|
||||||
|
|
||||||
if not self.fast_sync():
|
if not self.fast_sync():
|
||||||
dialog("ok", "{jellyfin}", translate(33128))
|
dialog("ok", "{jellyfin}", translate(33128))
|
||||||
|
|
Loading…
Reference in a new issue