Fix userclient
This commit is contained in:
parent
d16b931486
commit
a3c2d21757
17 changed files with 144 additions and 151 deletions
|
@ -397,6 +397,7 @@
|
||||||
<string id="39308">Could not log in user </string>
|
<string id="39308">Could not log in user </string>
|
||||||
<string id="39309">Please try again.</string>
|
<string id="39309">Please try again.</string>
|
||||||
<string id="39310">unknown</string>
|
<string id="39310">unknown</string>
|
||||||
|
<string id="39311">or press No to not sign in.</string>
|
||||||
|
|
||||||
<!-- Plex Librarysync.py -->
|
<!-- Plex Librarysync.py -->
|
||||||
<string id="39400">Library sync thread has crashed. You should restart Kodi now. Please report this on the forum</string>
|
<string id="39400">Library sync thread has crashed. You should restart Kodi now. Please report this on the forum</string>
|
||||||
|
|
|
@ -329,6 +329,7 @@
|
||||||
<string id="39308">Anmeldung fehlgeschlagen für Benutzer </string>
|
<string id="39308">Anmeldung fehlgeschlagen für Benutzer </string>
|
||||||
<string id="39309">Bitte erneut versuchen.</string>
|
<string id="39309">Bitte erneut versuchen.</string>
|
||||||
<string id="39310">unbekannt</string>
|
<string id="39310">unbekannt</string>
|
||||||
|
<string id="39311">oder Nein drücken, um nicht bei plex.tv anzumelden</string>
|
||||||
|
|
||||||
<!-- Plex Librarysync.py -->
|
<!-- Plex Librarysync.py -->
|
||||||
<string id="39400">Die Synchronisierung der Plex Bibliotheken ist abgestürzt. Bitte Kodi neu starten. Danke, wenn Sie sich die Zeit nehmen und im Plex Forum vom Absturz berichten.</string>
|
<string id="39400">Die Synchronisierung der Plex Bibliotheken ist abgestürzt. Bitte Kodi neu starten. Danke, wenn Sie sich die Zeit nehmen und im Plex Forum vom Absturz berichten.</string>
|
||||||
|
|
|
@ -67,7 +67,7 @@ except ImportError:
|
||||||
class PlexAPI():
|
class PlexAPI():
|
||||||
# CONSTANTS
|
# CONSTANTS
|
||||||
# Timeout for POST/GET commands, I guess in seconds
|
# Timeout for POST/GET commands, I guess in seconds
|
||||||
timeout = 60
|
timeout = 10
|
||||||
# VARIABLES
|
# VARIABLES
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
|
@ -79,9 +79,9 @@ class PlexAPI():
|
||||||
self.deviceName = client.getDeviceName()
|
self.deviceName = client.getDeviceName()
|
||||||
self.plexversion = client.getVersion()
|
self.plexversion = client.getVersion()
|
||||||
self.platform = client.getPlatform()
|
self.platform = client.getPlatform()
|
||||||
self.userId = utils.window('emby_currUser')
|
self.userId = utils.window('currUserId')
|
||||||
self.token = utils.window('emby_accessToken%s' % self.userId)
|
self.token = utils.window('pms_token')
|
||||||
self.server = utils.window('emby_server%s' % self.userId)
|
self.server = utils.window('pms_server')
|
||||||
|
|
||||||
self.doUtils = downloadutils.DownloadUtils()
|
self.doUtils = downloadutils.DownloadUtils()
|
||||||
|
|
||||||
|
@ -182,9 +182,11 @@ class PlexAPI():
|
||||||
dialog.ok(self.addonName, string(39303))
|
dialog.ok(self.addonName, string(39303))
|
||||||
return False
|
return False
|
||||||
# Go to https://plex.tv/pin and enter the code:
|
# Go to https://plex.tv/pin and enter the code:
|
||||||
|
# Or press No to cancel the sign in.
|
||||||
answer = dialog.yesno(self.addonName,
|
answer = dialog.yesno(self.addonName,
|
||||||
string(39304) + "\n\n",
|
string(39304) + "\n\n",
|
||||||
code)
|
code + "\n\n",
|
||||||
|
string(39311))
|
||||||
if not answer:
|
if not answer:
|
||||||
return False
|
return False
|
||||||
count = 0
|
count = 0
|
||||||
|
@ -638,14 +640,17 @@ class PlexAPI():
|
||||||
else:
|
else:
|
||||||
# MyPlex servers
|
# MyPlex servers
|
||||||
self.getPMSListFromMyPlex(ATV_udid, authtoken)
|
self.getPMSListFromMyPlex(ATV_udid, authtoken)
|
||||||
|
# Delete plex.tv again
|
||||||
|
del self.g_PMS[ATV_udid]['plex.tv']
|
||||||
# all servers - update enableGzip
|
# all servers - update enableGzip
|
||||||
for uuid_id in self.g_PMS.get(ATV_udid, {}):
|
for uuid_id in self.g_PMS.get(ATV_udid, {}):
|
||||||
# Ping to check whether we need HTTPs or HTTP
|
# Ping to check whether we need HTTPs or HTTP
|
||||||
url = (self.getPMSProperty(ATV_udid, uuid_id, 'ip') + ':'
|
url = (self.getPMSProperty(ATV_udid, uuid_id, 'ip') + ':'
|
||||||
+ self.getPMSProperty(ATV_udid, uuid_id, 'port'))
|
+ self.getPMSProperty(ATV_udid, uuid_id, 'port'))
|
||||||
if PMSHttpsEnabled(url):
|
if PMSHttpsEnabled(url):
|
||||||
self.logMsg('PMS %s talks HTTPS' % uuid_id, 1)
|
|
||||||
self.updatePMSProperty(ATV_udid, uuid_id, 'scheme', 'https')
|
self.updatePMSProperty(ATV_udid, uuid_id, 'scheme', 'https')
|
||||||
|
else:
|
||||||
|
self.updatePMSProperty(ATV_udid, uuid_id, 'scheme', 'http')
|
||||||
# enable Gzip if not on same host, local&remote PMS depending
|
# enable Gzip if not on same host, local&remote PMS depending
|
||||||
# on setting
|
# on setting
|
||||||
enableGzip = (not self.getPMSProperty(ATV_udid, uuid_id, 'ip') == IP_self) \
|
enableGzip = (not self.getPMSProperty(ATV_udid, uuid_id, 'ip') == IP_self) \
|
||||||
|
@ -657,8 +662,6 @@ class PlexAPI():
|
||||||
and True) == 'True'
|
and True) == 'True'
|
||||||
)
|
)
|
||||||
self.updatePMSProperty(ATV_udid, uuid_id, 'enableGzip', enableGzip)
|
self.updatePMSProperty(ATV_udid, uuid_id, 'enableGzip', enableGzip)
|
||||||
# Delete plex.tv again
|
|
||||||
del self.g_PMS[ATV_udid]['plex.tv']
|
|
||||||
|
|
||||||
def getPMSListFromMyPlex(self, ATV_udid, authtoken):
|
def getPMSListFromMyPlex(self, ATV_udid, authtoken):
|
||||||
"""
|
"""
|
||||||
|
@ -1128,13 +1131,18 @@ class PlexAPI():
|
||||||
trials += 1
|
trials += 1
|
||||||
continue
|
continue
|
||||||
# Switch to this Plex Home user, if applicable
|
# Switch to this Plex Home user, if applicable
|
||||||
username, usertoken = self.PlexSwitchHomeUser(
|
result = self.PlexSwitchHomeUser(
|
||||||
user['id'],
|
user['id'],
|
||||||
pin,
|
pin,
|
||||||
plexToken,
|
plexToken,
|
||||||
utils.settings('plex_machineIdentifier'))
|
utils.settings('plex_machineIdentifier'))
|
||||||
|
if result:
|
||||||
|
# Successfully retrieved username: break out of while loop
|
||||||
|
username = result['username']
|
||||||
|
usertoken = result['usertoken']
|
||||||
|
break
|
||||||
# Couldn't get user auth
|
# Couldn't get user auth
|
||||||
if not username:
|
else:
|
||||||
trials += 1
|
trials += 1
|
||||||
# Could not login user, please try again
|
# Could not login user, please try again
|
||||||
if not dialog.yesno(self.addonName,
|
if not dialog.yesno(self.addonName,
|
||||||
|
@ -1142,9 +1150,6 @@ class PlexAPI():
|
||||||
string(39309)):
|
string(39309)):
|
||||||
# User chose to cancel
|
# User chose to cancel
|
||||||
break
|
break
|
||||||
else:
|
|
||||||
# Successfully retrieved username: break out of while loop
|
|
||||||
break
|
|
||||||
|
|
||||||
if not username:
|
if not username:
|
||||||
self.logMsg('Failed signing in a user to plex.tv', -1)
|
self.logMsg('Failed signing in a user to plex.tv', -1)
|
||||||
|
@ -1161,6 +1166,7 @@ class PlexAPI():
|
||||||
def PlexSwitchHomeUser(self, userId, pin, token, machineIdentifier):
|
def PlexSwitchHomeUser(self, userId, pin, token, machineIdentifier):
|
||||||
"""
|
"""
|
||||||
Retrieves Plex home token for a Plex home user.
|
Retrieves Plex home token for a Plex home user.
|
||||||
|
Returns False if unsuccessful
|
||||||
|
|
||||||
Input:
|
Input:
|
||||||
userId id of the Plex home user
|
userId id of the Plex home user
|
||||||
|
@ -1168,9 +1174,14 @@ class PlexAPI():
|
||||||
token token for plex.tv
|
token token for plex.tv
|
||||||
|
|
||||||
Output:
|
Output:
|
||||||
(username, token)
|
{
|
||||||
|
'username'
|
||||||
|
'usertoken' Might be empty strings if no token found
|
||||||
|
for the machineIdentifier that was chosen
|
||||||
|
}
|
||||||
|
|
||||||
Returns 2 empty strings if unsuccessful
|
Also sets the settings variable settings('accessToken'),
|
||||||
|
settings('userid') and settings('username') with new plex token
|
||||||
"""
|
"""
|
||||||
url = 'https://plex.tv/api/home/users/' + userId + '/switch'
|
url = 'https://plex.tv/api/home/users/' + userId + '/switch'
|
||||||
if pin:
|
if pin:
|
||||||
|
@ -1181,32 +1192,50 @@ class PlexAPI():
|
||||||
answer.attrib
|
answer.attrib
|
||||||
except:
|
except:
|
||||||
self.logMsg('Error: plex.tv switch HomeUser change failed', -1)
|
self.logMsg('Error: plex.tv switch HomeUser change failed', -1)
|
||||||
return ('', '')
|
return False
|
||||||
|
|
||||||
username = answer.attrib.get('title', '')
|
username = answer.attrib.get('title', '')
|
||||||
token = answer.attrib.get('authenticationToken', '')
|
token = answer.attrib.get('authenticationToken', '')
|
||||||
|
userid = answer.attrib.get('id', '')
|
||||||
|
|
||||||
# Get final token
|
# Write to settings file
|
||||||
|
utils.settings('username', username)
|
||||||
|
utils.settings('userid', userid)
|
||||||
|
utils.settings('accessToken', token)
|
||||||
|
|
||||||
|
# Get final token to the PMS we've chosen
|
||||||
url = 'https://plex.tv/api/resources?includeHttps=1'
|
url = 'https://plex.tv/api/resources?includeHttps=1'
|
||||||
xml = self.TalkToPlexServer(url, talkType="GET", token=token)
|
xml = self.TalkToPlexServer(url, talkType="GET", token=token)
|
||||||
try:
|
try:
|
||||||
xml.attrib
|
xml.attrib
|
||||||
except:
|
except:
|
||||||
self.logMsg('switch HomeUser failed - plex.tv answer wrong', -1)
|
self.logMsg('Answer from plex.tv not as excepted', -1)
|
||||||
return ('', '')
|
# Set to empty iterable list for loop
|
||||||
|
xml = []
|
||||||
|
|
||||||
found = 0
|
found = 0
|
||||||
|
self.logMsg('Our machineIdentifier is %s' % machineIdentifier, 0)
|
||||||
for device in xml:
|
for device in xml:
|
||||||
if device.attrib.get('clientIdentifier') == machineIdentifier:
|
identifier = device.attrib.get('clientIdentifier')
|
||||||
|
self.logMsg('Found a Plex machineIdentifier: %s' % identifier, 0)
|
||||||
|
if (identifier in machineIdentifier or
|
||||||
|
machineIdentifier in identifier):
|
||||||
found += 1
|
found += 1
|
||||||
token = device.attrib.get('accessToken')
|
token = device.attrib.get('accessToken')
|
||||||
if found == 0:
|
|
||||||
self.logMsg('No tokens found for your server!', -1)
|
|
||||||
return ('', '')
|
|
||||||
|
|
||||||
self.logMsg('Plex.tv switch HomeUser change successfull', 0)
|
result = {
|
||||||
self.logMsg("username: %s, token: xxxx. " % username, 0)
|
'username': username,
|
||||||
return (username, token)
|
}
|
||||||
|
if found == 0:
|
||||||
|
self.logMsg('No tokens found for your server!', 0)
|
||||||
|
self.logMsg('Using empty string as token', 0)
|
||||||
|
result['usertoken'] = ''
|
||||||
|
else:
|
||||||
|
result['usertoken'] = token
|
||||||
|
|
||||||
|
self.logMsg('Plex.tv switch HomeUser change successfull for user %s'
|
||||||
|
% username, 0)
|
||||||
|
return result
|
||||||
|
|
||||||
def MyPlexListHomeUsers(self, authtoken):
|
def MyPlexListHomeUsers(self, authtoken):
|
||||||
"""
|
"""
|
||||||
|
@ -1430,9 +1459,9 @@ class API():
|
||||||
self.clientId = self.clientinfo.getDeviceId()
|
self.clientId = self.clientinfo.getDeviceId()
|
||||||
self.__language__ = xbmcaddon.Addon().getLocalizedString
|
self.__language__ = xbmcaddon.Addon().getLocalizedString
|
||||||
|
|
||||||
self.userId = utils.window('emby_currUser')
|
self.userId = utils.window('currUserId')
|
||||||
self.server = utils.window('emby_server%s' % self.userId)
|
self.server = utils.window('pms_server')
|
||||||
self.token = utils.window('emby_accessToken%s' % self.userId)
|
self.token = utils.window('pms_token')
|
||||||
|
|
||||||
def setPartNumber(self, number=None):
|
def setPartNumber(self, number=None):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -36,6 +36,7 @@ class PlexCompanion(threading.Thread):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
start_count = 0
|
start_count = 0
|
||||||
|
window = utils.window
|
||||||
while True:
|
while True:
|
||||||
try:
|
try:
|
||||||
httpd = listener.ThreadedHTTPServer(
|
httpd = listener.ThreadedHTTPServer(
|
||||||
|
@ -67,6 +68,12 @@ class PlexCompanion(threading.Thread):
|
||||||
if self.threadStopped():
|
if self.threadStopped():
|
||||||
break
|
break
|
||||||
xbmc.sleep(3000)
|
xbmc.sleep(3000)
|
||||||
|
# If we are not authorized, sleep
|
||||||
|
# Otherwise, we trigger a download which leads to a
|
||||||
|
# re-authorizations
|
||||||
|
if window('emby_serverStatus'):
|
||||||
|
xbmc.sleep(3000)
|
||||||
|
continue
|
||||||
try:
|
try:
|
||||||
|
|
||||||
httpd.handle_request()
|
httpd.handle_request()
|
||||||
|
|
|
@ -357,14 +357,17 @@ def PMSHttpsEnabled(url):
|
||||||
|
|
||||||
This is done by GET /identity (returns an error if https is enabled and we
|
This is done by GET /identity (returns an error if https is enabled and we
|
||||||
are trying to use http)
|
are trying to use http)
|
||||||
|
|
||||||
|
Prefers HTTPS over HTTP
|
||||||
"""
|
"""
|
||||||
xml = downloadutils.DownloadUtils().downloadUrl('http://%s/identity' % url)
|
xml = downloadutils.DownloadUtils().downloadUrl(
|
||||||
|
'https://%s/identity' % url)
|
||||||
try:
|
try:
|
||||||
# received a valid XML - http connection is possible
|
# received a valid XML - https connection is possible
|
||||||
xml.attrib
|
xml.attrib
|
||||||
logMsg('PMSHttpsEnabled', 'PMS on %s talks HTTP' % url, 1)
|
|
||||||
return False
|
|
||||||
except:
|
|
||||||
# couldn't get an xml - switch to https traffic
|
|
||||||
logMsg('PMSHttpsEnabled', 'PMS on %s talks HTTPS' % url, 1)
|
logMsg('PMSHttpsEnabled', 'PMS on %s talks HTTPS' % url, 1)
|
||||||
return True
|
return True
|
||||||
|
except:
|
||||||
|
# couldn't get an xml - switch to http traffic
|
||||||
|
logMsg('PMSHttpsEnabled', 'PMS on %s talks HTTPS' % url, 1)
|
||||||
|
return False
|
||||||
|
|
|
@ -38,8 +38,8 @@ class Artwork():
|
||||||
if not self.xbmc_port and self.enableTextureCache:
|
if not self.xbmc_port and self.enableTextureCache:
|
||||||
self.setKodiWebServerDetails()
|
self.setKodiWebServerDetails()
|
||||||
|
|
||||||
self.userId = utils.window('emby_currUser')
|
self.userId = utils.window('currUserId')
|
||||||
self.server = utils.window('emby_server%s' % self.userId)
|
self.server = utils.window('pms_server')
|
||||||
|
|
||||||
def double_urlencode(self, text):
|
def double_urlencode(self, text):
|
||||||
text = self.single_urlencode(text)
|
text = self.single_urlencode(text)
|
||||||
|
|
|
@ -222,10 +222,9 @@ class DownloadUtils():
|
||||||
# request session does not exists
|
# request session does not exists
|
||||||
self.logMsg("Request session does not exist: start one", 1)
|
self.logMsg("Request session does not exist: start one", 1)
|
||||||
# Get user information
|
# Get user information
|
||||||
self.userId = utils.window('emby_currUser')
|
self.userId = utils.window('currUserId')
|
||||||
self.server = utils.window('emby_server%s' % self.userId)
|
self.server = utils.window('pms_server')
|
||||||
self.token = utils.window(
|
self.token = utils.window('pms_token')
|
||||||
'emby_accessToken%s' % self.userId)
|
|
||||||
header = self.getHeader(options=headerOptions)
|
header = self.getHeader(options=headerOptions)
|
||||||
verifyssl = False
|
verifyssl = False
|
||||||
cert = None
|
cert = None
|
||||||
|
@ -378,6 +377,7 @@ class DownloadUtils():
|
||||||
# Emby server errors
|
# Emby server errors
|
||||||
if r.headers['X-Application-Error-Code'] == "ParentalControl":
|
if r.headers['X-Application-Error-Code'] == "ParentalControl":
|
||||||
# Parental control - access restricted
|
# Parental control - access restricted
|
||||||
|
self.logMsg('Setting emby_serverStatus to restricted')
|
||||||
utils.window('emby_serverStatus', value="restricted")
|
utils.window('emby_serverStatus', value="restricted")
|
||||||
xbmcgui.Dialog().notification(
|
xbmcgui.Dialog().notification(
|
||||||
heading=self.addonName,
|
heading=self.addonName,
|
||||||
|
@ -392,6 +392,7 @@ class DownloadUtils():
|
||||||
|
|
||||||
elif status not in ("401", "Auth"):
|
elif status not in ("401", "Auth"):
|
||||||
# Tell userclient token has been revoked.
|
# Tell userclient token has been revoked.
|
||||||
|
self.logMsg('Setting emby_serverStatus to 401')
|
||||||
utils.window('emby_serverStatus', value="401")
|
utils.window('emby_serverStatus', value="401")
|
||||||
self.logMsg("HTTP Error: %s" % e, 0)
|
self.logMsg("HTTP Error: %s" % e, 0)
|
||||||
xbmcgui.Dialog().notification(
|
xbmcgui.Dialog().notification(
|
||||||
|
|
|
@ -93,17 +93,15 @@ def reConnect():
|
||||||
utils.settings('plexLogin', value="")
|
utils.settings('plexLogin', value="")
|
||||||
utils.settings('plexToken', value=""),
|
utils.settings('plexToken', value=""),
|
||||||
utils.settings('plexid', value="")
|
utils.settings('plexid', value="")
|
||||||
utils.settings('plexHomeSize', value="")
|
utils.settings('plexHomeSize', value="1")
|
||||||
utils.settings('plexAvatar', value="")
|
utils.settings('plexAvatar', value="")
|
||||||
|
|
||||||
# Wait max for 5 seconds for all lib scans to finish
|
# Wait max for 5 seconds for all lib scans to finish
|
||||||
counter = 0
|
counter = 0
|
||||||
while utils.window('emby_dbScan') == 'true':
|
while utils.window('emby_dbScan') == 'true':
|
||||||
if counter > 100:
|
if counter > 100:
|
||||||
dialog.ok(
|
dialog.ok(heading=addonName,
|
||||||
heading=addonName,
|
message=string(39208))
|
||||||
message=string(39208),
|
|
||||||
)
|
|
||||||
# Resuming threads, just in case
|
# Resuming threads, just in case
|
||||||
utils.window('suspend_LibraryThread', clear=True)
|
utils.window('suspend_LibraryThread', clear=True)
|
||||||
# Abort reConnection
|
# Abort reConnection
|
||||||
|
@ -117,10 +115,8 @@ def reConnect():
|
||||||
counter = 0
|
counter = 0
|
||||||
while utils.window('emby_serverStatus') == "401":
|
while utils.window('emby_serverStatus') == "401":
|
||||||
if counter > 100:
|
if counter > 100:
|
||||||
dialog.ok(
|
dialog.ok(heading=addonName,
|
||||||
heading=addonName,
|
message=string(39208))
|
||||||
message=string(39208),
|
|
||||||
)
|
|
||||||
# Abort reConnection
|
# Abort reConnection
|
||||||
return
|
return
|
||||||
counter += 1
|
counter += 1
|
||||||
|
@ -343,7 +339,7 @@ def addUser():
|
||||||
clientInfo = clientinfo.ClientInfo()
|
clientInfo = clientinfo.ClientInfo()
|
||||||
deviceId = clientInfo.getDeviceId()
|
deviceId = clientInfo.getDeviceId()
|
||||||
deviceName = clientInfo.getDeviceName()
|
deviceName = clientInfo.getDeviceName()
|
||||||
userid = utils.window('emby_currUser')
|
userid = utils.window('currUserId')
|
||||||
dialog = xbmcgui.Dialog()
|
dialog = xbmcgui.Dialog()
|
||||||
|
|
||||||
# Get session
|
# Get session
|
||||||
|
|
|
@ -44,7 +44,8 @@ class InitialSetup():
|
||||||
plexLogin = plexdict['plexLogin']
|
plexLogin = plexdict['plexLogin']
|
||||||
plexToken = plexdict['plexToken']
|
plexToken = plexdict['plexToken']
|
||||||
plexid = plexdict['plexid']
|
plexid = plexdict['plexid']
|
||||||
self.logMsg('Plex info retrieved from settings', 1)
|
if plexToken:
|
||||||
|
self.logMsg('Found plex.tv token in settings', 0)
|
||||||
|
|
||||||
dialog = xbmcgui.Dialog()
|
dialog = xbmcgui.Dialog()
|
||||||
|
|
||||||
|
@ -54,6 +55,7 @@ class InitialSetup():
|
||||||
chk = self.plx.CheckConnection('plex.tv', plexToken)
|
chk = self.plx.CheckConnection('plex.tv', plexToken)
|
||||||
# HTTP Error: unauthorized. Token is no longer valid
|
# HTTP Error: unauthorized. Token is no longer valid
|
||||||
if chk == 401:
|
if chk == 401:
|
||||||
|
self.logMsg('plex.tv connection returned HTTP 401', 0)
|
||||||
# Delete token in the settings
|
# Delete token in the settings
|
||||||
utils.settings('plexToken', value='')
|
utils.settings('plexToken', value='')
|
||||||
# Could not login, please try again
|
# Could not login, please try again
|
||||||
|
@ -66,10 +68,12 @@ class InitialSetup():
|
||||||
plexid = result['plexid']
|
plexid = result['plexid']
|
||||||
elif chk is False or chk >= 400:
|
elif chk is False or chk >= 400:
|
||||||
# Problems connecting to plex.tv. Network or internet issue?
|
# Problems connecting to plex.tv. Network or internet issue?
|
||||||
|
self.logMsg('plex.tv connection returned HTTP %s'
|
||||||
|
% str(chk), 0)
|
||||||
dialog.ok(self.addonName,
|
dialog.ok(self.addonName,
|
||||||
string(39010))
|
string(39010))
|
||||||
else:
|
else:
|
||||||
# Successful connected to plex.tv
|
self.logMsg('plex.tv connection with token successful', 0)
|
||||||
# Refresh the info from Plex.tv
|
# Refresh the info from Plex.tv
|
||||||
url = 'https://plex.tv/'
|
url = 'https://plex.tv/'
|
||||||
path = 'users/account'
|
path = 'users/account'
|
||||||
|
@ -86,6 +90,7 @@ class InitialSetup():
|
||||||
self.logMsg('Updated Plex info from plex.tv', 0)
|
self.logMsg('Updated Plex info from plex.tv', 0)
|
||||||
else:
|
else:
|
||||||
self.logMsg('Failed to update Plex info from plex.tv', -1)
|
self.logMsg('Failed to update Plex info from plex.tv', -1)
|
||||||
|
|
||||||
# If a Plex server IP has already been set, return.
|
# If a Plex server IP has already been set, return.
|
||||||
if server and forcePlexTV is False:
|
if server and forcePlexTV is False:
|
||||||
self.logMsg("Server is already set.", 0)
|
self.logMsg("Server is already set.", 0)
|
||||||
|
|
|
@ -1595,8 +1595,8 @@ class Music(Items):
|
||||||
self.enableimportsongrating = utils.settings('enableImportSongRating') == "true"
|
self.enableimportsongrating = utils.settings('enableImportSongRating') == "true"
|
||||||
self.enableexportsongrating = utils.settings('enableExportSongRating') == "true"
|
self.enableexportsongrating = utils.settings('enableExportSongRating') == "true"
|
||||||
self.enableupdatesongrating = utils.settings('enableUpdateSongRating') == "true"
|
self.enableupdatesongrating = utils.settings('enableUpdateSongRating') == "true"
|
||||||
self.userid = utils.window('emby_currUser')
|
self.userid = utils.window('currUserId')
|
||||||
self.server = utils.window('emby_server%s' % self.userid)
|
self.server = utils.window('pms_server')
|
||||||
|
|
||||||
def __enter__(self):
|
def __enter__(self):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -34,8 +34,8 @@ class PlaybackUtils():
|
||||||
self.clientInfo = clientinfo.ClientInfo()
|
self.clientInfo = clientinfo.ClientInfo()
|
||||||
self.addonName = self.clientInfo.getAddonName()
|
self.addonName = self.clientInfo.getAddonName()
|
||||||
|
|
||||||
self.userid = utils.window('emby_currUser')
|
self.userid = utils.window('currUserId')
|
||||||
self.server = utils.window('emby_server%s' % self.userid)
|
self.server = utils.window('pms_server')
|
||||||
|
|
||||||
self.artwork = artwork.Artwork()
|
self.artwork = artwork.Artwork()
|
||||||
self.emby = embyserver.Read_EmbyServer()
|
self.emby = embyserver.Read_EmbyServer()
|
||||||
|
|
|
@ -21,8 +21,8 @@ import PlexAPI
|
||||||
class Playlist():
|
class Playlist():
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.userid = utils.window('emby_currUser')
|
self.userid = utils.window('currUserId')
|
||||||
self.server = utils.window('emby_server%s' % self.userid)
|
self.server = utils.window('pms_server')
|
||||||
|
|
||||||
self.emby = embyserver.Read_EmbyServer()
|
self.emby = embyserver.Read_EmbyServer()
|
||||||
|
|
||||||
|
|
|
@ -26,8 +26,8 @@ class PlayUtils():
|
||||||
|
|
||||||
self.clientInfo = clientinfo.ClientInfo()
|
self.clientInfo = clientinfo.ClientInfo()
|
||||||
|
|
||||||
self.userid = utils.window('emby_currUser')
|
self.userid = utils.window('currUserId')
|
||||||
self.server = utils.window('emby_server%s' % self.userid)
|
self.server = utils.window('pms_server')
|
||||||
self.machineIdentifier = utils.window('plex_machineIdentifier')
|
self.machineIdentifier = utils.window('plex_machineIdentifier')
|
||||||
|
|
||||||
def getPlayUrl(self, partNumber=None):
|
def getPlayUrl(self, partNumber=None):
|
||||||
|
|
|
@ -70,8 +70,8 @@ class SubscriptionManager:
|
||||||
WINDOW = xbmcgui.Window(10000)
|
WINDOW = xbmcgui.Window(10000)
|
||||||
|
|
||||||
# pbmc_server = str(WINDOW.getProperty('plexbmc.nowplaying.server'))
|
# pbmc_server = str(WINDOW.getProperty('plexbmc.nowplaying.server'))
|
||||||
# userId = str(WINDOW.getProperty('emby_currUser'))
|
# userId = str(WINDOW.getProperty('currUserId'))
|
||||||
# pbmc_server = str(WINDOW.getProperty('emby_server%s' % userId))
|
# pbmc_server = str(WINDOW.getProperty('pms_server'))
|
||||||
pbmc_server = None
|
pbmc_server = None
|
||||||
keyid = None
|
keyid = None
|
||||||
count = 0
|
count = 0
|
||||||
|
|
|
@ -19,8 +19,8 @@ class Read_EmbyServer():
|
||||||
|
|
||||||
self.doUtils = downloadutils.DownloadUtils().downloadUrl
|
self.doUtils = downloadutils.DownloadUtils().downloadUrl
|
||||||
|
|
||||||
self.userId = utils.window('emby_currUser')
|
self.userId = utils.window('currUserId')
|
||||||
self.server = utils.window('emby_server%s' % self.userId)
|
self.server = utils.window('pms_server')
|
||||||
|
|
||||||
def split_list(self, itemlist, size):
|
def split_list(self, itemlist, size):
|
||||||
# Split up list in pieces of size. Will generate a list of lists
|
# Split up list in pieces of size. Will generate a list of lists
|
||||||
|
|
|
@ -71,41 +71,6 @@ class UserClient(threading.Thread):
|
||||||
|
|
||||||
return logLevel
|
return logLevel
|
||||||
|
|
||||||
def getUserId(self, username=None):
|
|
||||||
|
|
||||||
log = self.logMsg
|
|
||||||
window = utils.window
|
|
||||||
settings = utils.settings
|
|
||||||
|
|
||||||
if username is None:
|
|
||||||
username = self.getUsername()
|
|
||||||
w_userId = window('emby_currUser')
|
|
||||||
s_userId = settings('userId')
|
|
||||||
|
|
||||||
# Verify the window property
|
|
||||||
if w_userId:
|
|
||||||
if not s_userId:
|
|
||||||
# Save access token if it's missing from settings
|
|
||||||
settings('userId', value=w_userId)
|
|
||||||
log("Returning userId %s from WINDOW for username %s"
|
|
||||||
% (w_userId, username), 0)
|
|
||||||
return w_userId
|
|
||||||
# Verify the settings
|
|
||||||
elif s_userId:
|
|
||||||
log("Returning userId %s from SETTINGS for username %s"
|
|
||||||
% (w_userId, username), 0)
|
|
||||||
return s_userId
|
|
||||||
# No userId found
|
|
||||||
log("No userId saved. Trying to get Plex to use instead", 0)
|
|
||||||
plexId = settings('plexid')
|
|
||||||
if not plexId:
|
|
||||||
log('Also no Plex ID found in settings', 0)
|
|
||||||
return ''
|
|
||||||
log('Using Plex ID %s as userid for username %s'
|
|
||||||
% (plexId, username), 0)
|
|
||||||
settings('userId', value=plexId)
|
|
||||||
return plexId
|
|
||||||
|
|
||||||
def getServer(self, prefix=True):
|
def getServer(self, prefix=True):
|
||||||
|
|
||||||
settings = utils.settings
|
settings = utils.settings
|
||||||
|
@ -135,37 +100,6 @@ class UserClient(threading.Thread):
|
||||||
elif not prefix:
|
elif not prefix:
|
||||||
return server
|
return server
|
||||||
|
|
||||||
def getToken(self, username=None, userId=None):
|
|
||||||
|
|
||||||
log = self.logMsg
|
|
||||||
window = utils.window
|
|
||||||
settings = utils.settings
|
|
||||||
|
|
||||||
if username is None:
|
|
||||||
username = self.getUsername()
|
|
||||||
if userId is None:
|
|
||||||
userId = self.getUserId()
|
|
||||||
w_token = window('emby_accessToken%s' % userId)
|
|
||||||
s_token = settings('accessToken')
|
|
||||||
|
|
||||||
# Verify the window property
|
|
||||||
if w_token:
|
|
||||||
if not s_token:
|
|
||||||
# Save access token if it's missing from settings
|
|
||||||
settings('accessToken', value=w_token)
|
|
||||||
log("Returning accessToken from WINDOW for username: %s "
|
|
||||||
"accessToken: xxxx" % username, 2)
|
|
||||||
return w_token
|
|
||||||
# Verify the settings
|
|
||||||
elif s_token:
|
|
||||||
log("Returning accessToken from SETTINGS for username: %s "
|
|
||||||
"accessToken: xxxx" % username, 2)
|
|
||||||
window('emby_accessToken%s' % userId, value=s_token)
|
|
||||||
return s_token
|
|
||||||
else:
|
|
||||||
log("No token found.", 1)
|
|
||||||
return ""
|
|
||||||
|
|
||||||
def getSSLverify(self):
|
def getSSLverify(self):
|
||||||
# Verify host certificate
|
# Verify host certificate
|
||||||
settings = utils.settings
|
settings = utils.settings
|
||||||
|
@ -245,9 +179,9 @@ class UserClient(threading.Thread):
|
||||||
|
|
||||||
if authenticated is False:
|
if authenticated is False:
|
||||||
self.logMsg('Testing validity of current token', 0)
|
self.logMsg('Testing validity of current token', 0)
|
||||||
window('emby_currUser', value=userId)
|
window('currUserId', value=userId)
|
||||||
window('plex_username', value=username)
|
window('plex_username', value=username)
|
||||||
window('emby_accessToken%s' % userId, value=self.currToken)
|
window('pms_token', value=self.currToken)
|
||||||
res = PlexAPI.PlexAPI().CheckConnection(
|
res = PlexAPI.PlexAPI().CheckConnection(
|
||||||
self.currServer, self.currToken)
|
self.currServer, self.currToken)
|
||||||
if res is False:
|
if res is False:
|
||||||
|
@ -261,10 +195,14 @@ class UserClient(threading.Thread):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
# Set to windows property
|
# Set to windows property
|
||||||
window('emby_currUser', value=userId)
|
window('currUserId', value=userId)
|
||||||
window('plex_username', value=username)
|
window('plex_username', value=username)
|
||||||
window('emby_accessToken%s' % userId, value=self.currToken)
|
# This is the token for the current PMS (might also be '')
|
||||||
window('emby_server%s' % userId, value=self.currServer)
|
window('pms_token', value=self.currToken)
|
||||||
|
# This is the token for plex.tv for the current user
|
||||||
|
# Is only '' if user is not signed in to plex.tv
|
||||||
|
window('plex_token', value=settings('accessToken'))
|
||||||
|
window('pms_server', value=self.currServer)
|
||||||
window('plex_machineIdentifier', value=self.machineIdentifier)
|
window('plex_machineIdentifier', value=self.machineIdentifier)
|
||||||
window('plex_servername', value=self.servername)
|
window('plex_servername', value=self.servername)
|
||||||
|
|
||||||
|
@ -387,12 +325,18 @@ class UserClient(threading.Thread):
|
||||||
|
|
||||||
def resetClient(self):
|
def resetClient(self):
|
||||||
self.logMsg("Reset UserClient authentication.", 1)
|
self.logMsg("Reset UserClient authentication.", 1)
|
||||||
|
|
||||||
|
self.doUtils.stopSession()
|
||||||
|
|
||||||
settings = utils.settings
|
settings = utils.settings
|
||||||
window = utils.window
|
window = utils.window
|
||||||
|
|
||||||
window('emby_accessToken%s' % self.currUserId, clear=True)
|
window('pms_token', clear=True)
|
||||||
window('emby_server%s' % self.currUserId, clear=True)
|
window('plex_token', clear=True)
|
||||||
window('emby_currUser', clear=True)
|
window('pms_server', clear=True)
|
||||||
|
window('plex_machineIdentifier', clear=True)
|
||||||
|
window('plex_servername', clear=True)
|
||||||
|
window('currUserId', clear=True)
|
||||||
window('plex_username', clear=True)
|
window('plex_username', clear=True)
|
||||||
|
|
||||||
settings('username', value='')
|
settings('username', value='')
|
||||||
|
@ -423,17 +367,21 @@ class UserClient(threading.Thread):
|
||||||
xbmc.sleep(1000)
|
xbmc.sleep(1000)
|
||||||
|
|
||||||
status = window('emby_serverStatus')
|
status = window('emby_serverStatus')
|
||||||
if status:
|
|
||||||
# Verify the connection status to server
|
|
||||||
if status == "restricted":
|
|
||||||
# Parental control is restricting access
|
|
||||||
self.HasAccess = False
|
|
||||||
|
|
||||||
elif status == "401":
|
if status == "Stop":
|
||||||
# Unauthorized access, revoke token
|
xbmc.sleep(500)
|
||||||
window('emby_serverStatus', value="Auth")
|
continue
|
||||||
self.resetClient()
|
|
||||||
xbmc.sleep(2000)
|
# Verify the connection status to server
|
||||||
|
elif status == "restricted":
|
||||||
|
# Parental control is restricting access
|
||||||
|
self.HasAccess = False
|
||||||
|
|
||||||
|
elif status == "401":
|
||||||
|
# Unauthorized access, revoke token
|
||||||
|
window('emby_serverStatus', value="Auth")
|
||||||
|
self.resetClient()
|
||||||
|
xbmc.sleep(2000)
|
||||||
|
|
||||||
if self.auth and (self.currUser is None):
|
if self.auth and (self.currUser is None):
|
||||||
# Try to authenticate user
|
# Try to authenticate user
|
||||||
|
@ -455,6 +403,7 @@ class UserClient(threading.Thread):
|
||||||
server = self.getServer()
|
server = self.getServer()
|
||||||
|
|
||||||
# The status Stop is for when user cancelled password dialog.
|
# The status Stop is for when user cancelled password dialog.
|
||||||
|
# Or retried too many times
|
||||||
if server and status != "Stop":
|
if server and status != "Stop":
|
||||||
# Only if there's information found to login
|
# Only if there's information found to login
|
||||||
log("Server found: %s" % server, 2)
|
log("Server found: %s" % server, 2)
|
||||||
|
|
|
@ -75,9 +75,10 @@ class Service():
|
||||||
|
|
||||||
"emby_online", "emby_serverStatus", "emby_onWake",
|
"emby_online", "emby_serverStatus", "emby_onWake",
|
||||||
"emby_syncRunning", "emby_dbCheck", "emby_kodiScan",
|
"emby_syncRunning", "emby_dbCheck", "emby_kodiScan",
|
||||||
"emby_shouldStop", "emby_currUser", "emby_dbScan", "emby_sessionId",
|
"emby_shouldStop", "currUserId", "emby_dbScan", "emby_sessionId",
|
||||||
"emby_initialScan", "emby_customplaylist", "emby_playbackProps",
|
"emby_initialScan", "emby_customplaylist", "emby_playbackProps",
|
||||||
"plex_runLibScan", "plex_username"
|
"plex_runLibScan", "plex_username", "pms_token", "plex_token",
|
||||||
|
"pms_server", "plex_machineIdentifier", "plex_servername"
|
||||||
]
|
]
|
||||||
for prop in properties:
|
for prop in properties:
|
||||||
window(prop, clear=True)
|
window(prop, clear=True)
|
||||||
|
|
Loading…
Add table
Reference in a new issue