From ae6289695ffa0d4916d9aaef3d4a08729aedea66 Mon Sep 17 00:00:00 2001 From: JackDandy Date: Tue, 20 Mar 2018 14:17:41 +0000 Subject: [PATCH] Change notify enabled Emby, Kodi, and Plex clients to update on deleted. --- CHANGES.md | 1 + sickbeard/webserve.py | 22 ++++++++++++++++++---- 2 files changed, 19 insertions(+), 4 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index 1419c587..76ca24ae 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -113,6 +113,7 @@ * Change removed NZBGet 'remote' PostProcess guidance until it is verified to work * Fix Trakt, recommended and watchlist (send_oauth is now sent) * Change some log messages from info to debug type +* Change notify enabled Emby, Kodi, and Plex clients to update deleted ### 0.14.9 (2018-03-19 13:10:00 UTC) diff --git a/sickbeard/webserve.py b/sickbeard/webserve.py index 8df1a8eb..446d19af 100644 --- a/sickbeard/webserve.py +++ b/sickbeard/webserve.py @@ -5474,13 +5474,13 @@ class History(MainHandler): row_show_ids.update({int(rowid): {int(tvid): int(shoid)}}) sql_results = my_db.select( - 'SELECT rowid, label, location' + 'SELECT rowid, tvep_id, label, location' ' FROM [tv_episodes_watched] WHERE `rowid` in (%s)' % ','.join([str(k) for k in row_show_ids.keys()]) ) h_records = [] removed = [] - deleted = [] + deleted = {} attempted = [] refresh = [] for r in sql_results: @@ -5500,7 +5500,7 @@ class History(MainHandler): if not ek.ek(os.path.isfile, r['location']): logger.log(u'Deleted file %s' % r['location']) - deleted += [r['location']] + deleted.update({r['tvep_id']: row_show_ids[r['rowid']]}) if row_show_ids[r['rowid']] not in refresh: # schedule a show for one refresh after deleting an arbitrary number of locations refresh += [row_show_ids[r['rowid']]] @@ -5515,6 +5515,20 @@ class History(MainHandler): if 1 == r_del.rowcount: removed += ['%s-%s-%s' % (r['rowid'], k, v) for k, v in row_show_ids[r['rowid']].iteritems()] + updating = False + for epid, tvid_shoid_dict in deleted.iteritems(): + sql_results = my_db.select('SELECT season, episode FROM [tv_episodes] WHERE `episode_id` = %s' % epid) + for r in sql_results: + show = helpers.find_show_by_id(sickbeard.showList, tvid_shoid_dict) + ep_obj = show.getEpisode(r['season'], r['episode']) + for n in filter(lambda x: x.name.lower() in ('emby', 'kodi', 'plex'), + notifiers.NotifierFactory().get_enabled()): + if 'PLEX' == n.name: + if updating: + continue + updating = True + n.update_library(show=show, show_name=show.name, ep_obj=ep_obj) + for tvid_shoid_dict in refresh: try: sickbeard.showQueueScheduler.action.refreshShow( @@ -5523,7 +5537,7 @@ class History(MainHandler): pass if not any([removed, h_records, len(deleted)]): - msg = 'No items removed, removed, or files deleted' + msg = 'No items removed and no files deleted' else: msg = [] if deleted: