From bb782a5debb45c5d1420bb72f0b1ce2466d3520c Mon Sep 17 00:00:00 2001 From: croneter Date: Wed, 22 Dec 2021 14:42:59 +0100 Subject: [PATCH] Fix Kodi library being empty for PKC direct paths if Masterlock has been activated --- resources/lib/initialsetup.py | 42 ++---------------------------- resources/lib/sources.py | 48 +++++++++++++++++++++++++++++++++++ 2 files changed, 50 insertions(+), 40 deletions(-) create mode 100644 resources/lib/sources.py diff --git a/resources/lib/initialsetup.py b/resources/lib/initialsetup.py index 9d4809287..45b6997fc 100644 --- a/resources/lib/initialsetup.py +++ b/resources/lib/initialsetup.py @@ -5,7 +5,6 @@ from xbmc import executebuiltin from . import utils -import xml.etree.ElementTree as etree from . import path_ops from . import migration from .downloadutils import DownloadUtils as DU, exceptions @@ -14,6 +13,7 @@ from . import json_rpc as js from . import app from . import variables as v +from . import sources ############################################################################### @@ -454,31 +454,6 @@ def write_pms_to_settings(server): server['machineIdentifier'], server['ip'], server['port'], server['scheme']) - @staticmethod - def _add_sources(root, extension): - changed = False - count = 2 - for source in root.findall('.//path'): - if source.text == extension: - count -= 1 - if count == 0: - # sources already set - break - else: - # Missing smb:// occurences, re-add. - changed = True - for _ in range(0, count): - source = etree.SubElement(root, 'source') - etree.SubElement( - source, - 'name').text = "PlexKodiConnect Masterlock Hack" - etree.SubElement( - source, - 'path', - {'pathversion': "1"}).text = extension - etree.SubElement(source, 'allowsharing').text = "true" - return changed - def setup(self): """ Initial setup. Run once upon startup. @@ -520,20 +495,7 @@ def setup(self): LOG.info('Current Kodi video memory cache in bytes: %s', cache) utils.settings('kodi_video_cache', value=cache) - # Hack to make PKC Kodi master lock compatible - try: - with utils.XmlKodiSetting('sources.xml', - force_create=True, - top_element='sources') as xml: - changed = False - for extension in ('smb://', 'nfs://'): - root = xml.set_setting(['video']) - changed = self._add_sources(root, extension) or changed - if changed: - xml.write_xml = True - reboot = True - except utils.ParseError: - pass + reboot = sources.pkc_sources_hack() or reboot # Do we need to migrate stuff? migration.check_migration() diff --git a/resources/lib/sources.py b/resources/lib/sources.py new file mode 100644 index 000000000..c01b708ee --- /dev/null +++ b/resources/lib/sources.py @@ -0,0 +1,48 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- +import xml.etree.ElementTree as etree + +from . import utils + + +def pkc_sources_hack(): + # Hack to make PKC Kodi master lock compatible + try: + with utils.XmlKodiSetting('sources.xml', + force_create=True, + top_element='sources') as xml: + changed = False + for extension in ('smb://', 'nfs://'): + root = xml.set_setting(['video']) + changed = add_source(root, extension) or changed + if changed: + xml.write_xml = True + except utils.ParseError: + pass + return changed + + +def add_source(root, source_path): + changed = False + # Originally, 2 sources were necessary for the PKC Masterlock Hack + count = 1 + for source in root.findall('.//path'): + if source.text == source_path: + count -= 1 + if count == 0: + # sources already set + break + else: + # Missing smb:// occurences, re-add. + changed = True + for _ in range(0, count): + source = etree.SubElement(root, 'source') + etree.SubElement( + source, + 'name').text = "PlexKodiConnect Masterlock Hack" + etree.SubElement( + source, + 'path', + {'pathversion': "1"}).text = source_path + etree.SubElement(source, 'allowsharing').text = "true" + return changed