summaryrefslogtreecommitdiffstats
path: root/addons/metadata.tvshows.themoviedb.org.python/libs/settings.py
diff options
context:
space:
mode:
Diffstat (limited to 'addons/metadata.tvshows.themoviedb.org.python/libs/settings.py')
-rw-r--r--addons/metadata.tvshows.themoviedb.org.python/libs/settings.py111
1 files changed, 111 insertions, 0 deletions
diff --git a/addons/metadata.tvshows.themoviedb.org.python/libs/settings.py b/addons/metadata.tvshows.themoviedb.org.python/libs/settings.py
new file mode 100644
index 0000000..3d6cf7d
--- /dev/null
+++ b/addons/metadata.tvshows.themoviedb.org.python/libs/settings.py
@@ -0,0 +1,111 @@
+# -*- coding: UTF-8 -*-
+#
+# Copyright (C) 2020, Team Kodi
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <https://www.gnu.org/licenses/>.
+# pylint: disable=missing-docstring
+
+import json
+import sys
+import urllib.parse
+from .utils import logger
+from . import api_utils
+from xbmcaddon import Addon
+from datetime import datetime, timedelta
+
+
+def _get_date_numeric(datetime_):
+ return (datetime_ - datetime(1970, 1, 1)).total_seconds()
+
+
+def _get_configuration():
+ logger.debug('getting configuration details')
+ return api_utils.load_info('https://api.themoviedb.org/3/configuration', params={'api_key': TMDB_CLOWNCAR}, verboselog=VERBOSELOG)
+
+
+def _load_base_urls():
+ image_root_url = ADDON.getSettingString('originalUrl')
+ preview_root_url = ADDON.getSettingString('previewUrl')
+ last_updated = ADDON.getSettingString('lastUpdated')
+ if not image_root_url or not preview_root_url or not last_updated or \
+ float(last_updated) < _get_date_numeric(datetime.now() - timedelta(days=30)):
+ conf = _get_configuration()
+ if conf:
+ image_root_url = conf['images']['secure_base_url'] + 'original'
+ preview_root_url = conf['images']['secure_base_url'] + 'w780'
+ ADDON.setSetting('originalUrl', image_root_url)
+ ADDON.setSetting('previewUrl', preview_root_url)
+ ADDON.setSetting('lastUpdated', str(
+ _get_date_numeric(datetime.now())))
+ return image_root_url, preview_root_url
+
+
+ADDON = Addon()
+TMDB_CLOWNCAR = 'af3a53eb387d57fc935e9128468b1899'
+FANARTTV_CLOWNCAR = 'b018086af0e1478479adfc55634db97d'
+TRAKT_CLOWNCAR = '90901c6be3b2de5a4fa0edf9ab5c75e9a5a0fef2b4ee7373d8b63dcf61f95697'
+MAXIMAGES = 200
+FANARTTV_MAPPING = {'showbackground': 'backdrops',
+ 'tvposter': 'posters',
+ 'tvbanner': 'banner',
+ 'hdtvlogo': 'clearlogo',
+ 'clearlogo': 'clearlogo',
+ 'hdclearart': 'clearart',
+ 'clearart': 'clearart',
+ 'tvthumb': 'landscape',
+ 'characterart': 'characterart',
+ 'seasonposter': 'seasonposters',
+ 'seasonbanner': 'seasonbanner',
+ 'seasonthumb': 'seasonlandscape'
+ }
+
+try:
+ source_params = dict(urllib.parse.parse_qsl(sys.argv[2]))
+except IndexError:
+ source_params = {}
+source_settings = json.loads(source_params.get('pathSettings', '{}'))
+
+KEEPTITLE = source_settings.get(
+ 'keeporiginaltitle', ADDON.getSettingBool('keeporiginaltitle'))
+CATLANDSCAPE = source_settings.get('cat_landscape', True)
+STUDIOCOUNTRY = source_settings.get('studio_country', False)
+ENABTRAILER = source_settings.get(
+ 'enab_trailer', ADDON.getSettingBool('enab_trailer'))
+PLAYERSOPT = source_settings.get(
+ 'players_opt', ADDON.getSettingString('players_opt')).lower()
+VERBOSELOG = source_settings.get(
+ 'verboselog', ADDON.getSettingBool('verboselog'))
+LANG = source_settings.get('language', ADDON.getSettingString('language'))
+CERT_COUNTRY = source_settings.get(
+ 'tmdbcertcountry', ADDON.getSettingString('tmdbcertcountry')).lower()
+IMAGEROOTURL, PREVIEWROOTURL = _load_base_urls()
+
+if source_settings.get('usecertprefix', ADDON.getSettingBool('usecertprefix')):
+ CERT_PREFIX = source_settings.get(
+ 'certprefix', ADDON.getSettingString('certprefix'))
+else:
+ CERT_PREFIX = ''
+primary_rating = source_settings.get(
+ 'ratings', ADDON.getSettingString('ratings')).lower()
+RATING_TYPES = [primary_rating]
+if source_settings.get('imdbanyway', ADDON.getSettingBool('imdbanyway')) and primary_rating != 'imdb':
+ RATING_TYPES.append('imdb')
+if source_settings.get('traktanyway', ADDON.getSettingBool('traktanyway')) and primary_rating != 'trakt':
+ RATING_TYPES.append('trakt')
+if source_settings.get('tmdbanyway', ADDON.getSettingBool('tmdbanyway')) and primary_rating != 'tmdb':
+ RATING_TYPES.append('tmdb')
+FANARTTV_ENABLE = source_settings.get(
+ 'enable_fanarttv', ADDON.getSettingBool('enable_fanarttv'))
+FANARTTV_CLIENTKEY = source_settings.get(
+ 'fanarttv_clientkey', ADDON.getSettingString('fanarttv_clientkey'))