mirror of
https://github.com/jellyfin/jellyfin-kodi.git
synced 2025-01-12 19:16:10 +00:00
Check db version
This commit is contained in:
parent
949714f22a
commit
40ac4a0e8c
5 changed files with 61 additions and 280 deletions
|
@ -446,6 +446,14 @@ msgctxt "#33021"
|
||||||
msgid "Gathering:"
|
msgid "Gathering:"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
msgctxt "#33022"
|
||||||
|
msgid "Detected the database needs to be recreated for this version of Emby for Kodi. Proceed?"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
msgctxt "#33023"
|
||||||
|
msgid "Emby for Kodi will work correctly until the database is reset."
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
msgctxt "#33025"
|
msgctxt "#33025"
|
||||||
msgid "Completed in:"
|
msgid "Completed in:"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
|
@ -148,283 +148,18 @@ class EmbyDatabase():
|
||||||
def remove_media_by_parent_id(self, *args):
|
def remove_media_by_parent_id(self, *args):
|
||||||
self.cursor.execute(QU.delete_media_by_parent_id, args)
|
self.cursor.execute(QU.delete_media_by_parent_id, args)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
"""
|
|
||||||
def get_version(self, version=None):
|
def get_version(self, version=None):
|
||||||
|
|
||||||
if version is not None:
|
if version is not None:
|
||||||
self.embycursor.execute("DELETE FROM version")
|
|
||||||
query = "INSERT INTO version(idVersion) VALUES (?)"
|
self.cursor.execute(QU.delete_version)
|
||||||
self.embycursor.execute(query, (version,))
|
self.cursor.execute(QU.add_version, (version,))
|
||||||
else:
|
else:
|
||||||
query = "SELECT idVersion FROM version"
|
|
||||||
self.embycursor.execute(query)
|
|
||||||
try:
|
try:
|
||||||
version = self.embycursor.fetchone()[0]
|
self.cursor.execute(QU.get_version)
|
||||||
except TypeError:
|
version = self.cursor.fetchone()[0]
|
||||||
|
except Exception as error:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
return version
|
return version
|
||||||
|
|
||||||
def getViews(self):
|
|
||||||
|
|
||||||
views = []
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"SELECT view_id",
|
|
||||||
"FROM view"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query)
|
|
||||||
rows = self.embycursor.fetchall()
|
|
||||||
for row in rows:
|
|
||||||
views.append(row[0])
|
|
||||||
|
|
||||||
return views
|
|
||||||
|
|
||||||
def getView_embyId(self, item_id):
|
|
||||||
# Returns ancestors using embyId
|
|
||||||
url = "{server}/emby/Items/%s/Ancestors?UserId={UserId}&format=json" % item_id
|
|
||||||
|
|
||||||
try:
|
|
||||||
view_list = self.download(url)
|
|
||||||
except Exception as error:
|
|
||||||
log.info("Error getting views: " + str(error))
|
|
||||||
view_list = []
|
|
||||||
|
|
||||||
if view_list is None:
|
|
||||||
view_list = []
|
|
||||||
|
|
||||||
for view in view_list:
|
|
||||||
|
|
||||||
if view['Type'] == "CollectionFolder":
|
|
||||||
# Found view
|
|
||||||
view_id = view['Id']
|
|
||||||
break
|
|
||||||
else: # No view found
|
|
||||||
return [None, None]
|
|
||||||
|
|
||||||
# Compare to view table in emby database
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"SELECT view_name",
|
|
||||||
"FROM view",
|
|
||||||
"WHERE view_id = ?"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query, (view_id,))
|
|
||||||
try:
|
|
||||||
view_name = self.embycursor.fetchone()[0]
|
|
||||||
except TypeError:
|
|
||||||
view_name = None
|
|
||||||
|
|
||||||
return [view_name, view_id]
|
|
||||||
|
|
||||||
def getView_byId(self, viewid):
|
|
||||||
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"SELECT view_name, media_type, kodi_tagid",
|
|
||||||
"FROM view",
|
|
||||||
"WHERE view_id = ?"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query, (viewid,))
|
|
||||||
view = self.embycursor.fetchone()
|
|
||||||
|
|
||||||
return view
|
|
||||||
|
|
||||||
def getView_byType(self, mediatype):
|
|
||||||
|
|
||||||
views = []
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"SELECT view_id, view_name",
|
|
||||||
"FROM view",
|
|
||||||
"WHERE media_type = ?"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query, (mediatype,))
|
|
||||||
rows = self.embycursor.fetchall()
|
|
||||||
for row in rows:
|
|
||||||
views.append({
|
|
||||||
|
|
||||||
'id': row[0],
|
|
||||||
'name': row[1],
|
|
||||||
'mediatype': mediatype
|
|
||||||
})
|
|
||||||
|
|
||||||
if mediatype in ('tvshows', 'movies'):
|
|
||||||
query = ' '.join((
|
|
||||||
"SELECT view_id, view_name",
|
|
||||||
"FROM view",
|
|
||||||
"WHERE media_type = ?"
|
|
||||||
))
|
|
||||||
|
|
||||||
self.embycursor.execute(query, ("mixed",))
|
|
||||||
rows = self.embycursor.fetchall()
|
|
||||||
for row in rows:
|
|
||||||
views.append({
|
|
||||||
|
|
||||||
'id': row[0],
|
|
||||||
'name': row[1],
|
|
||||||
'mediatype': "mixed"
|
|
||||||
})
|
|
||||||
|
|
||||||
return views
|
|
||||||
|
|
||||||
def getView_byName(self, tagname):
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"SELECT view_id",
|
|
||||||
"FROM view",
|
|
||||||
"WHERE view_name = ?"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query, (tagname,))
|
|
||||||
try:
|
|
||||||
view = self.embycursor.fetchone()[0]
|
|
||||||
|
|
||||||
except TypeError:
|
|
||||||
view = None
|
|
||||||
|
|
||||||
return view
|
|
||||||
|
|
||||||
def addView(self, embyid, name, mediatype, tagid, group_series):
|
|
||||||
|
|
||||||
query = (
|
|
||||||
'''
|
|
||||||
INSERT INTO view(
|
|
||||||
view_id, view_name, media_type, kodi_tagid, group_series)
|
|
||||||
|
|
||||||
VALUES (?, ?, ?, ?, ?)
|
|
||||||
'''
|
|
||||||
)
|
|
||||||
self.embycursor.execute(query, (embyid, name, mediatype, tagid, group_series))
|
|
||||||
|
|
||||||
def get_view_grouped_series(self, view_id):
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"SELECT group_series",
|
|
||||||
"FROM view",
|
|
||||||
"WHERE view_id = ?"
|
|
||||||
))
|
|
||||||
try:
|
|
||||||
self.embycursor.execute(query, (view_id,))
|
|
||||||
return self.embycursor.fetchone()
|
|
||||||
except: return False
|
|
||||||
|
|
||||||
def update_view_grouped_series(self, view_id, group_series):
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"UPDATE view",
|
|
||||||
"SET group_series = ?",
|
|
||||||
"WHERE view_id = ?"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query, (group_series, view_id))
|
|
||||||
|
|
||||||
def updateView(self, name, tagid, mediafolderid):
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"UPDATE view",
|
|
||||||
"SET view_name = ?, kodi_tagid = ?",
|
|
||||||
"WHERE view_id = ?"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query, (name, tagid, mediafolderid))
|
|
||||||
|
|
||||||
def removeView(self, viewid):
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"DELETE FROM view",
|
|
||||||
"WHERE view_id = ?"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query, (viewid,))
|
|
||||||
|
|
||||||
def getItem_byId(self, embyid):
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"SELECT kodi_id, kodi_fileid, kodi_pathid, parent_id, media_type, emby_type",
|
|
||||||
"FROM emby",
|
|
||||||
"WHERE emby_id = ?"
|
|
||||||
))
|
|
||||||
try:
|
|
||||||
self.embycursor.execute(query, (embyid,))
|
|
||||||
item = self.embycursor.fetchone()
|
|
||||||
return item
|
|
||||||
except: return None
|
|
||||||
|
|
||||||
def getItem_byView(self, mediafolderid):
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"SELECT kodi_id",
|
|
||||||
"FROM emby",
|
|
||||||
"WHERE media_folder = ?"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query, (mediafolderid,))
|
|
||||||
return self.embycursor.fetchall()
|
|
||||||
|
|
||||||
def get_item_by_view(self, view_id):
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"SELECT emby_id",
|
|
||||||
"FROM emby",
|
|
||||||
"WHERE media_folder = ?"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query, (view_id,))
|
|
||||||
return self.embycursor.fetchall()
|
|
||||||
|
|
||||||
|
|
||||||
def get_checksum_by_view(self, media_type, view_id):
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"SELECT emby_id, checksum",
|
|
||||||
"FROM emby",
|
|
||||||
"WHERE emby_type = ?",
|
|
||||||
"AND media_folder = ?"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query, (media_type, view_id,))
|
|
||||||
return self.embycursor.fetchall()
|
|
||||||
|
|
||||||
def getMediaType_byId(self, embyid):
|
|
||||||
|
|
||||||
query = ' '.join((
|
|
||||||
|
|
||||||
"SELECT emby_type",
|
|
||||||
"FROM emby",
|
|
||||||
"WHERE emby_id = ?"
|
|
||||||
))
|
|
||||||
self.embycursor.execute(query, (embyid,))
|
|
||||||
try:
|
|
||||||
itemtype = self.embycursor.fetchone()[0]
|
|
||||||
|
|
||||||
except TypeError:
|
|
||||||
itemtype = None
|
|
||||||
|
|
||||||
return itemtype
|
|
||||||
|
|
||||||
def sortby_mediaType(self, itemids, unsorted=True):
|
|
||||||
|
|
||||||
sorted_items = {}
|
|
||||||
|
|
||||||
for itemid in itemids:
|
|
||||||
|
|
||||||
mediatype = self.getMediaType_byId(itemid)
|
|
||||||
if mediatype:
|
|
||||||
sorted_items.setdefault(mediatype, []).append(itemid)
|
|
||||||
elif unsorted:
|
|
||||||
sorted_items.setdefault('Unsorted', []).append(itemid)
|
|
||||||
|
|
||||||
return sorted_items
|
|
||||||
|
|
||||||
"""
|
|
||||||
|
|
|
@ -80,6 +80,9 @@ get_items_by_media = """ SELECT emby_id
|
||||||
FROM emby
|
FROM emby
|
||||||
WHERE media_type = ?
|
WHERE media_type = ?
|
||||||
"""
|
"""
|
||||||
|
get_version = """ SELECT idVersion
|
||||||
|
FROM version
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -116,6 +119,9 @@ add_reference_song_obj = [ "{Id}","{SongId}",None,"{PathId}","Audio","song"
|
||||||
add_view = """ INSERT OR REPLACE INTO view(view_id, view_name, media_type)
|
add_view = """ INSERT OR REPLACE INTO view(view_id, view_name, media_type)
|
||||||
VALUES (?, ?, ?)
|
VALUES (?, ?, ?)
|
||||||
"""
|
"""
|
||||||
|
add_version = """ INSERT OR REPLACE INTO version(idVersion)
|
||||||
|
VALUES (?)
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
update_reference = """ UPDATE emby
|
update_reference = """ UPDATE emby
|
||||||
|
@ -172,3 +178,5 @@ delete_parent_boxset_obj = [ None, "{Movie}"
|
||||||
delete_media_by_parent_id = """ DELETE FROM emby
|
delete_media_by_parent_id = """ DELETE FROM emby
|
||||||
WHERE emby_parent_id = ?
|
WHERE emby_parent_id = ?
|
||||||
"""
|
"""
|
||||||
|
delete_version = """ DELETE FROM version
|
||||||
|
"""
|
||||||
|
|
|
@ -22,6 +22,7 @@ from views import Views, verify_kodi_defaults
|
||||||
from helper import _, window, settings, event, dialog, find, compare_version
|
from helper import _, window, settings, event, dialog, find, compare_version
|
||||||
from downloader import get_objects
|
from downloader import get_objects
|
||||||
from emby import Emby
|
from emby import Emby
|
||||||
|
from database import Database, emby_db, reset
|
||||||
|
|
||||||
#################################################################################################
|
#################################################################################################
|
||||||
|
|
||||||
|
@ -68,6 +69,8 @@ class Service(xbmc.Monitor):
|
||||||
LOG.warn("Using dynamic paths: %s", settings('useDirectPaths') == "0")
|
LOG.warn("Using dynamic paths: %s", settings('useDirectPaths') == "0")
|
||||||
LOG.warn("Log Level: %s", self.settings['log_level'])
|
LOG.warn("Log Level: %s", self.settings['log_level'])
|
||||||
|
|
||||||
|
self.check_version()
|
||||||
|
|
||||||
verify_kodi_defaults()
|
verify_kodi_defaults()
|
||||||
Views().get_nodes()
|
Views().get_nodes()
|
||||||
window('emby.connected.bool', True)
|
window('emby.connected.bool', True)
|
||||||
|
@ -132,6 +135,28 @@ class Service(xbmc.Monitor):
|
||||||
self.library_thread.stop_client()
|
self.library_thread.stop_client()
|
||||||
self.library_thread = None
|
self.library_thread = None
|
||||||
|
|
||||||
|
def check_version(self):
|
||||||
|
|
||||||
|
''' Check the database version to ensure we do not need to do a reset.
|
||||||
|
'''
|
||||||
|
with Database('emby') as embydb:
|
||||||
|
|
||||||
|
version = emby_db.EmbyDatabase(embydb.cursor).get_version()
|
||||||
|
LOG.info("---[ db/%s ]", version)
|
||||||
|
|
||||||
|
if version and compare_version(version, "3.1.0") < 0:
|
||||||
|
resp = dialog("yesno", heading=_('addon_name'), line1=_(33022))
|
||||||
|
|
||||||
|
if not resp:
|
||||||
|
|
||||||
|
LOG.warn("Database version is out of date! USER IGNORED!")
|
||||||
|
dialog("ok", heading=_('addon_name'), line1=_(33023))
|
||||||
|
|
||||||
|
raise Exception("User backed out of a required database reset")
|
||||||
|
else:
|
||||||
|
reset()
|
||||||
|
|
||||||
|
raise Exception("Completed database reset")
|
||||||
|
|
||||||
def check_update(self):
|
def check_update(self):
|
||||||
|
|
||||||
|
|
13
service.py
13
service.py
|
@ -38,9 +38,10 @@ DELAY = int(settings('startupDelay') or 0)
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
|
||||||
LOG.warn("--->[ service ]")
|
LOG.warn("-->[ service ]")
|
||||||
LOG.warn("Delay startup by %s seconds.", DELAY)
|
LOG.warn("Delay startup by %s seconds.", DELAY)
|
||||||
|
|
||||||
|
try:
|
||||||
session = Service()
|
session = Service()
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -48,9 +49,13 @@ if __name__ == "__main__":
|
||||||
raise Exception("Aborted during startup delay")
|
raise Exception("Aborted during startup delay")
|
||||||
|
|
||||||
session.service()
|
session.service()
|
||||||
except Exception as error:
|
except Exception as error: # TODO, build exceptions
|
||||||
|
|
||||||
LOG.exception(error)
|
LOG.exception(error)
|
||||||
session.shutdown()
|
session.shutdown()
|
||||||
|
|
||||||
LOG.warn("---<[ service ]")
|
except Exception as error:
|
||||||
|
''' Issue initializing the service.
|
||||||
|
'''
|
||||||
|
LOG.exception(error)
|
||||||
|
|
||||||
|
LOG.warn("--<[ service ]")
|
||||||
|
|
Loading…
Reference in a new issue