2018-11-08 21:22:16 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from logging import getLogger
|
|
|
|
|
2019-01-04 18:02:58 +01:00
|
|
|
from .common import KODIDB_LOCK
|
2018-11-08 21:22:16 +01:00
|
|
|
from .video import KodiVideoDB
|
|
|
|
from .music import KodiMusicDB
|
|
|
|
from .texture import KodiTextureDB
|
|
|
|
|
2019-11-14 08:13:23 +01:00
|
|
|
from .. import path_ops, utils, variables as v
|
2018-11-08 21:22:16 +01:00
|
|
|
|
|
|
|
LOG = getLogger('PLEX.kodi_db')
|
|
|
|
|
|
|
|
|
|
|
|
def kodiid_from_filename(path, kodi_type=None, db_type=None):
|
|
|
|
"""
|
|
|
|
Returns kodi_id if we have an item in the Kodi video or audio database with
|
|
|
|
said path. Feed with either koditype, e.v. 'movie', 'song' or the DB
|
|
|
|
you want to poll ('video' or 'music')
|
|
|
|
Returns None, <kodi_type> if not possible
|
|
|
|
"""
|
|
|
|
kodi_id = None
|
|
|
|
path = utils.try_decode(path)
|
2019-03-17 11:30:44 +01:00
|
|
|
# Make sure path ends in either '/' or '\'
|
2019-03-28 13:08:03 +01:00
|
|
|
# We CANNOT use path_ops.path.join as this can result in \ where we need /
|
|
|
|
try:
|
|
|
|
filename = path.rsplit('/', 1)[1]
|
|
|
|
path = path.rsplit('/', 1)[0] + '/'
|
|
|
|
except IndexError:
|
|
|
|
filename = path.rsplit('\\', 1)[1]
|
|
|
|
path = path.rsplit('\\', 1)[0] + '\\'
|
2018-11-08 21:22:16 +01:00
|
|
|
if kodi_type == v.KODI_TYPE_SONG or db_type == 'music':
|
2019-01-28 18:05:40 +01:00
|
|
|
with KodiMusicDB(lock=False) as kodidb:
|
2018-11-08 21:22:16 +01:00
|
|
|
try:
|
2018-11-13 09:02:34 +01:00
|
|
|
kodi_id = kodidb.song_id_from_filename(filename, path)
|
2018-11-08 21:22:16 +01:00
|
|
|
except TypeError:
|
|
|
|
LOG.debug('No Kodi audio db element found for path %s', path)
|
|
|
|
else:
|
|
|
|
kodi_type = v.KODI_TYPE_SONG
|
|
|
|
else:
|
2019-01-28 18:05:40 +01:00
|
|
|
with KodiVideoDB(lock=False) as kodidb:
|
2018-11-08 21:22:16 +01:00
|
|
|
try:
|
|
|
|
kodi_id, kodi_type = kodidb.video_id_from_filename(filename,
|
|
|
|
path)
|
|
|
|
except TypeError:
|
2018-11-23 08:54:09 +01:00
|
|
|
LOG.debug('No kodi video db element found for path %s file %s',
|
|
|
|
path, filename)
|
2018-11-08 21:22:16 +01:00
|
|
|
return kodi_id, kodi_type
|
|
|
|
|
|
|
|
|
|
|
|
def setup_kodi_default_entries():
|
|
|
|
"""
|
|
|
|
Makes sure that we retain the Kodi standard databases. E.g. that there
|
|
|
|
is a dummy artist with ID 1
|
|
|
|
"""
|
|
|
|
if utils.settings('enableMusic') == 'true':
|
|
|
|
with KodiMusicDB() as kodidb:
|
2019-11-14 08:13:23 +01:00
|
|
|
kodidb.setup_kodi_default_entries()
|
2018-11-08 21:22:16 +01:00
|
|
|
|
|
|
|
|
|
|
|
def reset_cached_images():
|
|
|
|
LOG.info('Resetting cached artwork')
|
2019-11-15 08:24:21 +01:00
|
|
|
LOG.debug('Resetting the Kodi texture DB')
|
2019-12-10 17:26:00 +01:00
|
|
|
with KodiTextureDB() as kodidb:
|
2019-11-15 08:24:21 +01:00
|
|
|
kodidb.wipe()
|
|
|
|
LOG.debug('Deleting all cached image files')
|
2018-11-08 21:22:16 +01:00
|
|
|
path = path_ops.translate_path('special://thumbnails/')
|
|
|
|
if path_ops.exists(path):
|
|
|
|
path_ops.rmtree(path, ignore_errors=True)
|
|
|
|
paths = ('', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
|
|
|
|
'a', 'b', 'c', 'd', 'e', 'f',
|
|
|
|
'Video', 'plex')
|
|
|
|
for path in paths:
|
|
|
|
new_path = path_ops.translate_path('special://thumbnails/%s' % path)
|
2018-12-02 17:46:35 +01:00
|
|
|
try:
|
2020-12-23 15:29:27 +01:00
|
|
|
path_ops.makedirs(new_path)
|
2019-11-15 08:24:21 +01:00
|
|
|
except OSError as err:
|
|
|
|
LOG.warn('Could not create thumbnail directory %s: %s',
|
|
|
|
new_path, err)
|
|
|
|
LOG.info('Done resetting cached artwork')
|
2018-11-08 21:22:16 +01:00
|
|
|
|
|
|
|
|
|
|
|
def wipe_dbs(music=True):
|
|
|
|
"""
|
|
|
|
Completely resets the Kodi databases 'video', 'texture' and 'music' (if
|
|
|
|
music sync is enabled)
|
2018-12-10 20:32:59 +01:00
|
|
|
|
2019-11-15 08:24:21 +01:00
|
|
|
We need to connect without sqlite WAL mode as Kodi might still be accessing
|
|
|
|
the dbs and we need to prevent that
|
2018-11-08 21:22:16 +01:00
|
|
|
"""
|
|
|
|
LOG.warn('Wiping Kodi databases!')
|
2019-11-15 08:24:21 +01:00
|
|
|
LOG.info('Wiping Kodi video database')
|
2019-12-10 17:26:00 +01:00
|
|
|
with KodiVideoDB() as kodidb:
|
2019-11-15 08:24:21 +01:00
|
|
|
kodidb.wipe()
|
2018-11-08 21:22:16 +01:00
|
|
|
if music:
|
2019-11-15 08:24:21 +01:00
|
|
|
LOG.info('Wiping Kodi music database')
|
2019-12-10 17:26:00 +01:00
|
|
|
with KodiMusicDB() as kodidb:
|
2019-11-14 08:13:23 +01:00
|
|
|
kodidb.wipe()
|
2019-11-15 08:24:21 +01:00
|
|
|
reset_cached_images()
|
2018-11-08 21:22:16 +01:00
|
|
|
setup_kodi_default_entries()
|
2018-11-13 09:28:19 +01:00
|
|
|
# Delete SQLITE wal files
|
2018-11-08 21:22:16 +01:00
|
|
|
import xbmc
|
2018-11-13 09:28:19 +01:00
|
|
|
# Make sure Kodi knows we wiped the databases
|
2018-11-08 21:22:16 +01:00
|
|
|
xbmc.executebuiltin('UpdateLibrary(video)')
|
|
|
|
if utils.settings('enableMusic') == 'true':
|
|
|
|
xbmc.executebuiltin('UpdateLibrary(music)')
|
|
|
|
|
|
|
|
|
2019-11-14 08:13:23 +01:00
|
|
|
def create_kodi_db_indicees():
|
|
|
|
"""
|
|
|
|
Index the "actors" because we got a TON - speed up SELECT and WHEN
|
|
|
|
"""
|
|
|
|
with KodiVideoDB() as kodidb:
|
|
|
|
kodidb.create_kodi_db_indicees()
|
|
|
|
|
|
|
|
|
2018-11-08 21:22:16 +01:00
|
|
|
KODIDB_FROM_PLEXTYPE = {
|
|
|
|
v.PLEX_TYPE_MOVIE: KodiVideoDB,
|
|
|
|
v.PLEX_TYPE_SHOW: KodiVideoDB,
|
|
|
|
v.PLEX_TYPE_SEASON: KodiVideoDB,
|
|
|
|
v.PLEX_TYPE_EPISODE: KodiVideoDB,
|
|
|
|
v.PLEX_TYPE_ARTIST: KodiMusicDB,
|
|
|
|
v.PLEX_TYPE_ALBUM: KodiMusicDB,
|
|
|
|
v.PLEX_TYPE_SONG: KodiMusicDB
|
|
|
|
}
|