2018-07-12 18:46:02 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from __future__ import absolute_import, division, unicode_literals
|
2017-05-29 17:29:29 +02:00
|
|
|
from logging import getLogger
|
2018-06-21 19:24:37 +02:00
|
|
|
|
|
|
|
from . import variables as v
|
|
|
|
from . import utils
|
2017-05-29 17:29:29 +02:00
|
|
|
###############################################################################
|
|
|
|
|
2018-06-21 19:24:37 +02:00
|
|
|
LOG = getLogger('PLEX.migration')
|
2017-05-29 17:29:29 +02:00
|
|
|
|
|
|
|
|
|
|
|
def check_migration():
|
2018-06-21 19:24:37 +02:00
|
|
|
LOG.info('Checking whether we need to migrate something')
|
|
|
|
last_migration = utils.settings('last_migrated_PKC_version')
|
2017-05-29 17:29:29 +02:00
|
|
|
if last_migration == v.ADDON_VERSION:
|
2018-06-21 19:24:37 +02:00
|
|
|
LOG.info('Already migrated to PKC version %s' % v.ADDON_VERSION)
|
2018-05-14 19:58:58 +02:00
|
|
|
# Ensure later migration if user downgraded PKC!
|
2018-06-21 19:24:37 +02:00
|
|
|
utils.settings('last_migrated_PKC_version', value=v.ADDON_VERSION)
|
2017-05-29 17:29:29 +02:00
|
|
|
return
|
|
|
|
|
2018-06-21 19:24:37 +02:00
|
|
|
if not utils.compare_version(last_migration, '1.8.2'):
|
|
|
|
LOG.info('Migrating to version 1.8.1')
|
2017-05-29 17:29:29 +02:00
|
|
|
# Set the new PKC theMovieDB key
|
2018-06-21 19:24:37 +02:00
|
|
|
utils.settings('themoviedbAPIKey',
|
|
|
|
value='19c90103adb9e98f2172c6a6a3d85dc4')
|
2017-05-29 17:29:29 +02:00
|
|
|
|
2018-06-21 19:24:37 +02:00
|
|
|
if not utils.compare_version(last_migration, '2.0.25'):
|
|
|
|
LOG.info('Migrating to version 2.0.24')
|
2018-05-14 19:42:00 +02:00
|
|
|
# Need to re-connect with PMS to pick up on plex.direct URIs
|
2018-06-21 19:24:37 +02:00
|
|
|
utils.settings('ipaddress', value='')
|
|
|
|
utils.settings('port', value='')
|
2018-05-14 19:42:00 +02:00
|
|
|
|
2019-03-09 15:18:59 +01:00
|
|
|
if not utils.compare_version(last_migration, '2.7.6'):
|
|
|
|
LOG.info('Migrating to version 2.7.5')
|
|
|
|
from .library_sync.sections import delete_files
|
|
|
|
delete_files()
|
|
|
|
|
2019-06-14 12:46:37 +02:00
|
|
|
if not utils.compare_version(last_migration, '2.8.3'):
|
|
|
|
LOG.info('Migrating to version 2.8.2')
|
|
|
|
from .library_sync import sections
|
|
|
|
sections.clear_window_vars()
|
|
|
|
sections.delete_videonode_files()
|
|
|
|
|
2019-06-28 15:27:02 +02:00
|
|
|
if not utils.compare_version(last_migration, '2.8.7'):
|
|
|
|
LOG.info('Migrating to version 2.8.6')
|
|
|
|
# Need to delete the UNIQUE index that prevents creating several
|
|
|
|
# playlist entries with the same kodi_hash
|
|
|
|
from .plex_db import PlexDB
|
|
|
|
with PlexDB() as plexdb:
|
|
|
|
plexdb.cursor.execute('DROP INDEX IF EXISTS ix_playlists_3')
|
|
|
|
# Index will be automatically recreated on next PKC startup
|
|
|
|
|
2019-07-06 21:22:12 +02:00
|
|
|
if not utils.compare_version(last_migration, '2.8.9'):
|
|
|
|
LOG.info('Migrating to version 2.8.8')
|
|
|
|
from .library_sync import sections
|
|
|
|
sections.clear_window_vars()
|
|
|
|
sections.delete_videonode_files()
|
|
|
|
|
2019-08-01 14:22:44 +02:00
|
|
|
if not utils.compare_version(last_migration, '2.9.3'):
|
|
|
|
LOG.info('Migrating to version 2.9.2')
|
|
|
|
# Re-sync all playlists to Kodi
|
|
|
|
utils.wipe_synched_playlists()
|
|
|
|
|
2018-06-21 19:24:37 +02:00
|
|
|
utils.settings('last_migrated_PKC_version', value=v.ADDON_VERSION)
|