mirror of
https://github.com/jellyfin/jellyfin-kodi.git
synced 2025-01-24 08:56:10 +00:00
Merge pull request #145 from TrueTechy/remove-connection-tests
Removed connection tests and minor cleanup
This commit is contained in:
commit
f44efb8e4c
10 changed files with 52 additions and 188 deletions
|
@ -147,8 +147,7 @@ class Connect(object):
|
||||||
settings('username', self.user['Name'])
|
settings('username', self.user['Name'])
|
||||||
|
|
||||||
if 'PrimaryImageTag' in self.user:
|
if 'PrimaryImageTag' in self.user:
|
||||||
server_data = client.auth.get_server_info(client.auth.server_id)
|
server_address = client.auth.get_server_info(client.auth.server_id)['address']
|
||||||
server_address = client.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
window('JellyfinUserImage', api.API(self.user, server_address).get_user_artwork(self.user['Id']))
|
window('JellyfinUserImage', api.API(self.user, server_address).get_user_artwork(self.user['Id']))
|
||||||
|
|
||||||
def select_servers(self, state=None):
|
def select_servers(self, state=None):
|
||||||
|
@ -212,8 +211,7 @@ class Connect(object):
|
||||||
def login(self):
|
def login(self):
|
||||||
|
|
||||||
users = self.connect_manager.get_public_users()
|
users = self.connect_manager.get_public_users()
|
||||||
server_data = self.connect_manager.get_server_info(self.connect_manager.server_id)
|
server = self.connect_manager.get_server_info(self.connect_manager.server_id)['address']
|
||||||
server = self.connect_manager.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
|
|
||||||
if not users:
|
if not users:
|
||||||
try:
|
try:
|
||||||
|
|
|
@ -117,8 +117,7 @@ class LoginManual(xbmcgui.WindowXMLDialog):
|
||||||
|
|
||||||
def _login(self, username, password):
|
def _login(self, username, password):
|
||||||
|
|
||||||
server_data = self.connect_manager.get_server_info(self.connect_manager.server_id)
|
server = self.connect_manager.get_server_info(self.connect_manager.server_id)['address']
|
||||||
server = self.connect_manager.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
result = self.connect_manager.login(server, username, password)
|
result = self.connect_manager.login(server, username, password)
|
||||||
|
|
||||||
if not result:
|
if not result:
|
||||||
|
|
|
@ -21,26 +21,11 @@ CONNECTION_STATE = {
|
||||||
'Unavailable': 0,
|
'Unavailable': 0,
|
||||||
'ServerSelection': 1,
|
'ServerSelection': 1,
|
||||||
'ServerSignIn': 2,
|
'ServerSignIn': 2,
|
||||||
'SignedIn': 3,
|
'SignedIn': 3
|
||||||
'ServerUpdateNeeded': 5
|
|
||||||
}
|
|
||||||
CONNECTION_MODE = {
|
|
||||||
'Local': 0,
|
|
||||||
'Manual': 2
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#################################################################################################
|
#################################################################################################
|
||||||
|
|
||||||
|
|
||||||
def get_server_address(server, mode):
|
|
||||||
|
|
||||||
modes = {
|
|
||||||
CONNECTION_MODE['Local']: server.get('LocalAddress'),
|
|
||||||
CONNECTION_MODE['Manual']: server.get('ManualAddress')
|
|
||||||
}
|
|
||||||
return modes.get(mode) or server.get('ManualAddress', server.get('LocalAddress'))
|
|
||||||
|
|
||||||
|
|
||||||
class ConnectionManager(object):
|
class ConnectionManager(object):
|
||||||
|
|
||||||
min_server_version = "10.1.0"
|
min_server_version = "10.1.0"
|
||||||
|
@ -138,55 +123,41 @@ class ConnectionManager(object):
|
||||||
|
|
||||||
address = self._normalize_address(address)
|
address = self._normalize_address(address)
|
||||||
|
|
||||||
def _on_fail():
|
|
||||||
LOG.error("connectToAddress %s failed", address)
|
|
||||||
return self._resolve_failure()
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
public_info = self._try_connect(address, options=options)
|
public_info = self._try_connect(address, options=options)
|
||||||
except Exception as error:
|
|
||||||
LOG.exception(error)
|
|
||||||
return _on_fail()
|
|
||||||
else:
|
|
||||||
LOG.info("connectToAddress %s succeeded", address)
|
LOG.info("connectToAddress %s succeeded", address)
|
||||||
server = {
|
server = {
|
||||||
'ManualAddress': address,
|
'address': address,
|
||||||
'LastConnectionMode': CONNECTION_MODE['Manual']
|
|
||||||
}
|
}
|
||||||
self._update_server_info(server, public_info)
|
self._update_server_info(server, public_info)
|
||||||
server = self.connect_to_server(server, options)
|
server = self.connect_to_server(server, options)
|
||||||
if server is False:
|
if server is False:
|
||||||
return _on_fail()
|
LOG.error("connectToAddress %s failed", address)
|
||||||
|
return { 'State': CONNECTION_STATE['Unavailable'] }
|
||||||
|
|
||||||
return server
|
return server
|
||||||
|
except Exception as error:
|
||||||
|
LOG.exception(error)
|
||||||
|
LOG.error("connectToAddress %s failed", address)
|
||||||
|
return { 'State': CONNECTION_STATE['Unavailable'] }
|
||||||
|
|
||||||
|
|
||||||
def connect_to_server(self, server, options={}):
|
def connect_to_server(self, server, options={}):
|
||||||
|
|
||||||
LOG.info("begin connectToServer")
|
LOG.info("begin connectToServer")
|
||||||
|
timeout = self.timeout
|
||||||
|
|
||||||
tests = []
|
try:
|
||||||
|
result = self._try_connect(server['address'], timeout, options)
|
||||||
|
LOG.info("calling onSuccessfulConnection with server %s", server.get('Name'))
|
||||||
|
credentials = self.credentials.get_credentials()
|
||||||
|
return self._after_connect_validated(server, credentials, result, True, options)
|
||||||
|
|
||||||
if server.get('LastConnectionMode') is not None and server.get('AccessToken'):
|
except Exception as e:
|
||||||
tests.append(server['LastConnectionMode'])
|
LOG.info("Failing server connection. ERROR msg: {}".format(e))
|
||||||
|
return { 'State': CONNECTION_STATE['Unavailable'] }
|
||||||
if CONNECTION_MODE['Manual'] not in tests:
|
|
||||||
tests.append(CONNECTION_MODE['Manual'])
|
|
||||||
if CONNECTION_MODE['Local'] not in tests:
|
|
||||||
tests.append(CONNECTION_MODE['Local'])
|
|
||||||
|
|
||||||
LOG.info("beginning connection tests")
|
|
||||||
return self._test_next_connection_mode(tests, 0, server, options)
|
|
||||||
|
|
||||||
def get_server_address(self, server, mode): # TODO: De-duplicated (Duplicated from above when getting rid of shortcuts)
|
|
||||||
|
|
||||||
modes = {
|
|
||||||
CONNECTION_MODE['Local']: server.get('LocalAddress'),
|
|
||||||
CONNECTION_MODE['Manual']: server.get('ManualAddress')
|
|
||||||
}
|
|
||||||
return modes.get(mode) or server.get('ManualAddress', server.get('LocalAddress'))
|
|
||||||
|
|
||||||
def connect(self, options={}):
|
def connect(self, options={}):
|
||||||
|
|
||||||
LOG.info("Begin connect")
|
LOG.info("Begin connect")
|
||||||
return self._connect_to_servers(self.get_available_servers(), options)
|
return self._connect_to_servers(self.get_available_servers(), options)
|
||||||
|
|
||||||
|
@ -284,91 +255,6 @@ class ConnectionManager(object):
|
||||||
'retry': False
|
'retry': False
|
||||||
})
|
})
|
||||||
|
|
||||||
def _test_next_connection_mode(self, tests, index, server, options):
|
|
||||||
|
|
||||||
if index >= len(tests):
|
|
||||||
LOG.info("Tested all connection modes. Failing server connection.")
|
|
||||||
return self._resolve_failure()
|
|
||||||
|
|
||||||
mode = tests[index]
|
|
||||||
address = get_server_address(server, mode)
|
|
||||||
enable_retry = False
|
|
||||||
skip_test = False
|
|
||||||
timeout = self.timeout
|
|
||||||
|
|
||||||
LOG.info("testing connection mode %s with server %s", mode, server.get('Name'))
|
|
||||||
|
|
||||||
if mode == CONNECTION_MODE['Local']:
|
|
||||||
enable_retry = True
|
|
||||||
timeout = 8
|
|
||||||
|
|
||||||
if self._string_equals_ignore_case(address, server.get('ManualAddress')):
|
|
||||||
LOG.info("skipping LocalAddress test because it is the same as ManualAddress")
|
|
||||||
skip_test = True
|
|
||||||
|
|
||||||
elif mode == CONNECTION_MODE['Manual']:
|
|
||||||
if self._string_equals_ignore_case(address, server.get('LocalAddress')):
|
|
||||||
enable_retry = True
|
|
||||||
timeout = 8
|
|
||||||
|
|
||||||
if skip_test or not address:
|
|
||||||
LOG.info("skipping test at index: %s", index)
|
|
||||||
return self._test_next_connection_mode(tests, index + 1, server, options)
|
|
||||||
|
|
||||||
try:
|
|
||||||
result = self._try_connect(address, timeout, options)
|
|
||||||
|
|
||||||
except Exception:
|
|
||||||
LOG.exception("test failed for connection mode %s with server %s", mode, server.get('Name'))
|
|
||||||
return self._test_next_connection_mode(tests, index + 1, server, options)
|
|
||||||
else:
|
|
||||||
if self._compare_versions(self._get_min_server_version(), result['Version']) == 1:
|
|
||||||
LOG.warning("minServerVersion requirement not met. Server version: %s", result['Version'])
|
|
||||||
return {
|
|
||||||
'State': CONNECTION_STATE['ServerUpdateNeeded'],
|
|
||||||
'Servers': [server]
|
|
||||||
}
|
|
||||||
else:
|
|
||||||
LOG.info("calling onSuccessfulConnection with connection mode %s with server %s", mode, server.get('Name'))
|
|
||||||
return self._on_successful_connection(server, result, mode, options)
|
|
||||||
|
|
||||||
def _on_successful_connection(self, server, system_info, connection_mode, options):
|
|
||||||
|
|
||||||
credentials = self.credentials.get_credentials()
|
|
||||||
return self._after_connect_validated(server, credentials, system_info, connection_mode, True, options)
|
|
||||||
|
|
||||||
def _resolve_failure(self):
|
|
||||||
return {
|
|
||||||
'State': CONNECTION_STATE['Unavailable']
|
|
||||||
}
|
|
||||||
|
|
||||||
def _get_min_server_version(self, val=None):
|
|
||||||
|
|
||||||
if val is not None:
|
|
||||||
self.min_server_version = val
|
|
||||||
|
|
||||||
return self.min_server_version
|
|
||||||
|
|
||||||
def _compare_versions(self, a, b):
|
|
||||||
|
|
||||||
''' -1 a is smaller
|
|
||||||
1 a is larger
|
|
||||||
0 equal
|
|
||||||
'''
|
|
||||||
a = LooseVersion(a)
|
|
||||||
b = LooseVersion(b)
|
|
||||||
|
|
||||||
if a < b:
|
|
||||||
return -1
|
|
||||||
|
|
||||||
if a > b:
|
|
||||||
return 1
|
|
||||||
|
|
||||||
return 0
|
|
||||||
|
|
||||||
def _string_equals_ignore_case(self, str1, str2):
|
|
||||||
return (str1 or "").lower() == (str2 or "").lower()
|
|
||||||
|
|
||||||
def _server_discovery(self):
|
def _server_discovery(self):
|
||||||
|
|
||||||
MULTI_GROUP = ("<broadcast>", 7359)
|
MULTI_GROUP = ("<broadcast>", 7359)
|
||||||
|
@ -440,10 +326,9 @@ class ConnectionManager(object):
|
||||||
|
|
||||||
info = {
|
info = {
|
||||||
'Id': found_server['Id'],
|
'Id': found_server['Id'],
|
||||||
'LocalAddress': server or found_server['Address'],
|
'address': server or found_server['Address'],
|
||||||
'Name': found_server['Name']
|
'Name': found_server['Name']
|
||||||
} # TODO
|
}
|
||||||
info['LastConnectionMode'] = CONNECTION_MODE['Manual'] if info.get('ManualAddress') else CONNECTION_MODE['Local']
|
|
||||||
|
|
||||||
servers.append(info)
|
servers.append(info)
|
||||||
else:
|
else:
|
||||||
|
@ -495,26 +380,23 @@ class ConnectionManager(object):
|
||||||
}
|
}
|
||||||
self.credentials.add_update_user(server, info)
|
self.credentials.add_update_user(server, info)
|
||||||
|
|
||||||
def _after_connect_validated(self, server, credentials, system_info, connection_mode, verify_authentication, options):
|
def _after_connect_validated(self, server, credentials, system_info, verify_authentication, options):
|
||||||
|
|
||||||
if options.get('enableAutoLogin') is False:
|
if options.get('enableAutoLogin') is False:
|
||||||
|
|
||||||
self.config.data['auth.user_id'] = server.pop('UserId', None)
|
self.config.data['auth.user_id'] = server.pop('UserId', None)
|
||||||
self.config.data['auth.token'] = server.pop('AccessToken', None)
|
self.config.data['auth.token'] = server.pop('AccessToken', None)
|
||||||
|
|
||||||
elif verify_authentication and server.get('AccessToken'):
|
elif verify_authentication and server.get('AccessToken'):
|
||||||
|
if self._validate_authentication(server, options) is not False:
|
||||||
if self._validate_authentication(server, connection_mode, options) is not False:
|
|
||||||
|
|
||||||
self.config.data['auth.user_id'] = server['UserId']
|
self.config.data['auth.user_id'] = server['UserId']
|
||||||
self.config.data['auth.token'] = server['AccessToken']
|
self.config.data['auth.token'] = server['AccessToken']
|
||||||
return self._after_connect_validated(server, credentials, system_info, connection_mode, False, options)
|
return self._after_connect_validated(server, credentials, system_info, False, options)
|
||||||
|
|
||||||
return self._resolve_failure()
|
return { 'State': CONNECTION_STATE['Unavailable'] }
|
||||||
|
|
||||||
self._update_server_info(server, system_info)
|
self._update_server_info(server, system_info)
|
||||||
self.server_version = system_info['Version']
|
self.server_version = system_info['Version']
|
||||||
server['LastConnectionMode'] = connection_mode
|
|
||||||
|
|
||||||
if options.get('updateDateLastAccessed') is not False:
|
if options.get('updateDateLastAccessed') is not False:
|
||||||
server['DateLastAccessed'] = datetime.now().strftime('%Y-%m-%dT%H:%M:%SZ')
|
server['DateLastAccessed'] = datetime.now().strftime('%Y-%m-%dT%H:%M:%SZ')
|
||||||
|
@ -524,7 +406,7 @@ class ConnectionManager(object):
|
||||||
self.server_id = server['Id']
|
self.server_id = server['Id']
|
||||||
|
|
||||||
# Update configs
|
# Update configs
|
||||||
self.config.data['auth.server'] = get_server_address(server, connection_mode)
|
self.config.data['auth.server'] = server['address']
|
||||||
self.config.data['auth.server-name'] = server['Name']
|
self.config.data['auth.server-name'] = server['Name']
|
||||||
self.config.data['auth.server=id'] = server['Id']
|
self.config.data['auth.server=id'] = server['Id']
|
||||||
self.config.data['auth.ssl'] = options.get('ssl', self.config.data['auth.ssl'])
|
self.config.data['auth.ssl'] = options.get('ssl', self.config.data['auth.ssl'])
|
||||||
|
@ -537,12 +419,12 @@ class ConnectionManager(object):
|
||||||
# Connected
|
# Connected
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def _validate_authentication(self, server, connection_mode, options={}):
|
def _validate_authentication(self, server, options={}):
|
||||||
|
|
||||||
try:
|
try:
|
||||||
system_info = self._request_url({
|
system_info = self._request_url({
|
||||||
'type': "GET",
|
'type': "GET",
|
||||||
'url': self.get_jellyfin_url(get_server_address(server, connection_mode), "System/Info"),
|
'url': self.get_jellyfin_url(server['address'], "System/Info"),
|
||||||
'verify': options.get('ssl'),
|
'verify': options.get('ssl'),
|
||||||
'dataType': "json",
|
'dataType': "json",
|
||||||
'headers': {
|
'headers': {
|
||||||
|
@ -566,8 +448,10 @@ class ConnectionManager(object):
|
||||||
server['Name'] = system_info['ServerName']
|
server['Name'] = system_info['ServerName']
|
||||||
server['Id'] = system_info['Id']
|
server['Id'] = system_info['Id']
|
||||||
|
|
||||||
if system_info.get('LocalAddress'):
|
if system_info.get('address'):
|
||||||
server['LocalAddress'] = system_info['LocalAddress']
|
server['address'] = system_info['address']
|
||||||
|
|
||||||
|
## Finish updating server info
|
||||||
|
|
||||||
def _on_authenticated(self, result, options={}):
|
def _on_authenticated(self, result, options={}):
|
||||||
|
|
||||||
|
|
|
@ -145,8 +145,7 @@ class Monitor(xbmc.Monitor):
|
||||||
|
|
||||||
elif method == 'GetServerAddress':
|
elif method == 'GetServerAddress':
|
||||||
|
|
||||||
server_data = server.auth.get_server_info(server.auth.server_id)
|
server_address = server.auth.get_server_info(server.auth.server_id)['address']
|
||||||
server_address = server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
self.void_responder(data, server_address)
|
self.void_responder(data, server_address)
|
||||||
|
|
||||||
elif method == 'GetPlaybackInfo':
|
elif method == 'GetPlaybackInfo':
|
||||||
|
|
|
@ -41,8 +41,7 @@ class Movies(KodiDb):
|
||||||
''' If item does not exist, entry will be added.
|
''' If item does not exist, entry will be added.
|
||||||
If item exists, entry will be updated.
|
If item exists, entry will be updated.
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'Movie')
|
obj = self.objects.map(item, 'Movie')
|
||||||
update = True
|
update = True
|
||||||
|
@ -195,8 +194,7 @@ class Movies(KodiDb):
|
||||||
Process movies inside boxset.
|
Process movies inside boxset.
|
||||||
Process removals from boxset.
|
Process removals from boxset.
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'Boxset')
|
obj = self.objects.map(item, 'Boxset')
|
||||||
|
|
||||||
|
@ -274,8 +272,7 @@ class Movies(KodiDb):
|
||||||
''' This updates: Favorite, LastPlayedDate, Playcount, PlaybackPositionTicks
|
''' This updates: Favorite, LastPlayedDate, Playcount, PlaybackPositionTicks
|
||||||
Poster with progress bar
|
Poster with progress bar
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'MovieUserData')
|
obj = self.objects.map(item, 'MovieUserData')
|
||||||
|
|
||||||
|
|
|
@ -40,8 +40,7 @@ class Music(KodiDb):
|
||||||
''' If item does not exist, entry will be added.
|
''' If item does not exist, entry will be added.
|
||||||
If item exists, entry will be updated.
|
If item exists, entry will be updated.
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'Artist')
|
obj = self.objects.map(item, 'Artist')
|
||||||
update = True
|
update = True
|
||||||
|
@ -107,8 +106,7 @@ class Music(KodiDb):
|
||||||
|
|
||||||
''' Update object to kodi.
|
''' Update object to kodi.
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'Album')
|
obj = self.objects.map(item, 'Album')
|
||||||
update = True
|
update = True
|
||||||
|
@ -214,8 +212,7 @@ class Music(KodiDb):
|
||||||
|
|
||||||
''' Update object to kodi.
|
''' Update object to kodi.
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'Song')
|
obj = self.objects.map(item, 'Song')
|
||||||
update = True
|
update = True
|
||||||
|
@ -331,8 +328,7 @@ class Music(KodiDb):
|
||||||
obj['Path'] = obj['Path'].replace(obj['Filename'], "")
|
obj['Path'] = obj['Path'].replace(obj['Filename'], "")
|
||||||
|
|
||||||
else:
|
else:
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
obj['Path'] = "%s/emby/Audio/%s/" % (server_address, obj['Id'])
|
obj['Path'] = "%s/emby/Audio/%s/" % (server_address, obj['Id'])
|
||||||
obj['Filename'] = "stream.%s?static=true" % obj['Container']
|
obj['Filename'] = "stream.%s?static=true" % obj['Container']
|
||||||
|
|
||||||
|
@ -409,8 +405,7 @@ class Music(KodiDb):
|
||||||
''' This updates: Favorite, LastPlayedDate, Playcount, PlaybackPositionTicks
|
''' This updates: Favorite, LastPlayedDate, Playcount, PlaybackPositionTicks
|
||||||
Poster with progress bar
|
Poster with progress bar
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'SongUserData')
|
obj = self.objects.map(item, 'SongUserData')
|
||||||
|
|
||||||
|
|
|
@ -45,8 +45,7 @@ class MusicVideos(KodiDb):
|
||||||
If we don't get the track number from Jellyfin, see if we can infer it
|
If we don't get the track number from Jellyfin, see if we can infer it
|
||||||
from the sortname attribute.
|
from the sortname attribute.
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'MusicVideo')
|
obj = self.objects.map(item, 'MusicVideo')
|
||||||
update = True
|
update = True
|
||||||
|
@ -180,8 +179,7 @@ class MusicVideos(KodiDb):
|
||||||
''' This updates: Favorite, LastPlayedDate, Playcount, PlaybackPositionTicks
|
''' This updates: Favorite, LastPlayedDate, Playcount, PlaybackPositionTicks
|
||||||
Poster with progress bar
|
Poster with progress bar
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'MusicVideoUserData')
|
obj = self.objects.map(item, 'MusicVideoUserData')
|
||||||
|
|
||||||
|
|
|
@ -48,8 +48,7 @@ class TVShows(KodiDb):
|
||||||
Process seasons.
|
Process seasons.
|
||||||
Apply series pooling.
|
Apply series pooling.
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'Series')
|
obj = self.objects.map(item, 'Series')
|
||||||
update = True
|
update = True
|
||||||
|
@ -205,8 +204,7 @@ class TVShows(KodiDb):
|
||||||
|
|
||||||
If the show is empty, try to remove it.
|
If the show is empty, try to remove it.
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'Season')
|
obj = self.objects.map(item, 'Season')
|
||||||
|
|
||||||
|
@ -241,8 +239,7 @@ class TVShows(KodiDb):
|
||||||
Create additional entry for widgets.
|
Create additional entry for widgets.
|
||||||
This is only required for plugin/episode.
|
This is only required for plugin/episode.
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'Episode')
|
obj = self.objects.map(item, 'Episode')
|
||||||
update = True
|
update = True
|
||||||
|
@ -431,8 +428,7 @@ class TVShows(KodiDb):
|
||||||
Make sure there's no other bookmarks created by widget.
|
Make sure there's no other bookmarks created by widget.
|
||||||
Create additional entry for widgets. This is only required for plugin/episode.
|
Create additional entry for widgets. This is only required for plugin/episode.
|
||||||
'''
|
'''
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(item, server_address)
|
API = api.API(item, server_address)
|
||||||
obj = self.objects.map(item, 'EpisodeUserData')
|
obj = self.objects.map(item, 'EpisodeUserData')
|
||||||
|
|
||||||
|
|
|
@ -251,8 +251,7 @@ class Player(xbmc.Player):
|
||||||
return
|
return
|
||||||
|
|
||||||
break
|
break
|
||||||
server_data = item['Server'].auth.get_server_info(item['Server'].auth.server_id)
|
server_address = item['Server'].auth.get_server_info(item['Server'].auth.server_id)['address']
|
||||||
server_address = item['Server'].auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
API = api.API(next_item, server_address)
|
API = api.API(next_item, server_address)
|
||||||
data = objects.map(next_item, "UpNext")
|
data = objects.map(next_item, "UpNext")
|
||||||
artwork = API.get_all_artwork(objects.map(next_item, 'ArtworkParent'), True)
|
artwork = API.get_all_artwork(objects.map(next_item, 'ArtworkParent'), True)
|
||||||
|
|
|
@ -860,8 +860,7 @@ class Views(object):
|
||||||
for library in self.media_folders:
|
for library in self.media_folders:
|
||||||
|
|
||||||
if library['Id'] == view_id and 'Primary' in library.get('ImageTags', {}):
|
if library['Id'] == view_id and 'Primary' in library.get('ImageTags', {}):
|
||||||
server_data = self.server.auth.get_server_info(self.server.auth.server_id)
|
server_address = self.server.auth.get_server_info(self.server.auth.server_id)['address']
|
||||||
server_address = self.server.auth.get_server_address(server_data, server_data['LastConnectionMode'])
|
|
||||||
artwork = api.API(None, server_address).get_artwork(view_id, 'Primary')
|
artwork = api.API(None, server_address).get_artwork(view_id, 'Primary')
|
||||||
window('%s.artwork' % prop, artwork)
|
window('%s.artwork' % prop, artwork)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue