bazarr/bazarr/get_episodes.py

218 lines
11 KiB
Python
Raw Normal View History

# coding=utf-8
import os
import requests
import logging
2019-02-08 03:34:54 +00:00
import re
from queueconfig import notifications
2019-08-22 18:58:08 +00:00
from database import TableShows, TableEpisodes, wal_cleaning
from get_args import args
2018-12-15 00:36:28 +00:00
from config import settings, url_sonarr
from helper import path_replace
2019-08-22 18:58:08 +00:00
from list_subtitles import list_missing_subtitles, store_subtitles, series_full_scan_subtitles
from get_subtitle import episode_download_subtitles
2019-01-15 16:25:13 +00:00
def update_all_episodes():
series_full_scan_subtitles()
logging.info('BAZARR All existing episode subtitles indexed from disk.')
list_missing_subtitles()
logging.info('BAZARR All missing episode subtitles updated in database.')
2019-08-22 18:58:08 +00:00
wal_cleaning()
def sync_episodes():
notifications.write(msg='Episodes sync from Sonarr started...', queue='get_episodes')
2018-12-14 04:01:15 +00:00
logging.debug('BAZARR Starting episodes sync from Sonarr.')
2018-12-15 00:36:28 +00:00
apikey_sonarr = settings.sonarr.apikey
# Get current episodes id in DB
2019-08-11 14:34:01 +00:00
current_episodes_db = TableEpisodes.select(
TableEpisodes.sonarr_episode_id,
TableEpisodes.path,
TableEpisodes.sonarr_series_id
)
current_episodes_db_list = [x.sonarr_episode_id for x in current_episodes_db]
current_episodes_sonarr = []
episodes_to_update = []
episodes_to_add = []
2019-08-11 14:34:01 +00:00
altered_episodes = []
2019-01-15 16:25:13 +00:00
# Get sonarrId for each series from database
2019-08-11 14:34:01 +00:00
seriesIdList = TableShows.select(
TableShows.sonarr_series_id,
TableShows.title
)
2019-01-15 16:25:13 +00:00
2019-08-11 14:34:01 +00:00
seriesIdListLength = seriesIdList.count()
2019-04-04 19:04:06 +00:00
for i, seriesId in enumerate(seriesIdList, 1):
2019-04-23 01:08:26 +00:00
notifications.write(msg='Getting episodes data from Sonarr...', queue='get_episodes', item=i, length=seriesIdListLength)
# Get episodes data for a series from Sonarr
2019-08-11 14:34:01 +00:00
url_sonarr_api_episode = url_sonarr + "/api/episode?seriesId=" + str(seriesId.sonarr_series_id) + "&apikey=" + apikey_sonarr
try:
2019-04-14 13:11:46 +00:00
r = requests.get(url_sonarr_api_episode, timeout=60, verify=False)
r.raise_for_status()
except requests.exceptions.HTTPError as errh:
logging.exception("BAZARR Error trying to get episodes from Sonarr. Http error.")
except requests.exceptions.ConnectionError as errc:
logging.exception("BAZARR Error trying to get episodes from Sonarr. Connection Error.")
except requests.exceptions.Timeout as errt:
logging.exception("BAZARR Error trying to get episodes from Sonarr. Timeout Error.")
except requests.exceptions.RequestException as err:
logging.exception("BAZARR Error trying to get episodes from Sonarr.")
else:
for episode in r.json():
if 'hasFile' in episode:
if episode['hasFile'] is True:
if 'episodeFile' in episode:
if episode['episodeFile']['size'] > 20480:
# Add shows in Sonarr to current shows list
if 'sceneName' in episode['episodeFile']:
sceneName = episode['episodeFile']['sceneName']
else:
sceneName = None
2019-02-06 11:51:19 +00:00
try:
format, resolution = episode['episodeFile']['quality']['quality']['name'].split('-')
except:
format = episode['episodeFile']['quality']['quality']['name']
try:
resolution = str(episode['episodeFile']['quality']['quality']['resolution']) + 'p'
except:
resolution = None
2019-02-06 11:51:19 +00:00
if 'mediaInfo' in episode['episodeFile']:
if 'videoCodec' in episode['episodeFile']['mediaInfo']:
videoCodec = episode['episodeFile']['mediaInfo']['videoCodec']
videoCodec = SonarrFormatVideoCodec(videoCodec)
else: videoCodec = None
2019-02-08 03:34:54 +00:00
if 'audioCodec' in episode['episodeFile']['mediaInfo']:
audioCodec = episode['episodeFile']['mediaInfo']['audioCodec']
audioCodec = SonarrFormatAudioCodec(audioCodec)
else: audioCodec = None
else:
videoCodec = None
audioCodec = None
2019-02-08 03:34:54 +00:00
# Add episodes in sonarr to current episode list
current_episodes_sonarr.append(episode['id'])
2019-01-15 16:25:13 +00:00
if episode['id'] in current_episodes_db_list:
2019-08-11 14:34:01 +00:00
episodes_to_update.append({'sonarr_series_id': episode['seriesId'],
'sonarr_episode_id': episode['id'],
'title': episode['title'],
'path': episode['episodeFile']['path'],
'season': episode['seasonNumber'],
'episode': episode['episodeNumber'],
'scene_name': sceneName,
'monitored': str(bool(episode['monitored'])),
'format': format,
'resolution': resolution,
'video_codec': videoCodec,
'audio_codec': audioCodec})
else:
2019-08-11 14:34:01 +00:00
episodes_to_add.append({'sonarr_series_id': episode['seriesId'],
'sonarr_episode_id': episode['id'],
'title': episode['title'],
'path': episode['episodeFile']['path'],
'season': episode['seasonNumber'],
'episode': episode['episodeNumber'],
'scene_name': sceneName,
'monitored': str(bool(episode['monitored'])),
'format': format,
'resolution': resolution,
'video_codec': videoCodec,
'audio_codec': audioCodec})
# Update existing episodes in DB
episode_in_db_list = []
episodes_in_db = TableEpisodes.select(
TableEpisodes.sonarr_series_id,
TableEpisodes.sonarr_episode_id,
TableEpisodes.title,
TableEpisodes.path,
TableEpisodes.season,
TableEpisodes.episode,
TableEpisodes.scene_name,
TableEpisodes.monitored,
TableEpisodes.format,
TableEpisodes.resolution,
TableEpisodes.video_codec,
TableEpisodes.audio_codec
).dicts()
for item in episodes_in_db:
episode_in_db_list.append(item)
episodes_to_update_list = [i for i in episodes_to_update if i not in episode_in_db_list]
for updated_episode in episodes_to_update_list:
TableEpisodes.update(
updated_episode
).where(
TableEpisodes.sonarr_episode_id == updated_episode['sonarr_episode_id']
).execute()
altered_episodes.append([updated_episode['sonarr_episode_id'],
updated_episode['path'],
updated_episode['sonarr_series_id']])
# Insert new episodes in DB
for added_episode in episodes_to_add:
TableEpisodes.insert(
added_episode
).on_conflict_ignore().execute()
altered_episodes.append([added_episode['sonarr_episode_id'],
added_episode['path'],
added_episode['sonarr_series_id']])
# Remove old episodes from DB
removed_episodes = list(set(current_episodes_db_list) - set(current_episodes_sonarr))
for removed_episode in removed_episodes:
TableEpisodes.delete().where(
TableEpisodes.sonarr_episode_id == removed_episode
).execute()
# Store subtitles for added or modified episodes
for altered_episode in altered_episodes:
store_subtitles(path_replace(altered_episode[1]))
list_missing_subtitles(altered_episode[2])
logging.debug('BAZARR All episodes synced from Sonarr into database.')
# Search for desired subtitles if no more than 5 episodes have been added.
if len(altered_episodes) <= 5:
logging.debug("BAZARR No more than 5 episodes were added during this sync then we'll search for subtitles.")
for altered_episode in altered_episodes:
episode_download_subtitles(altered_episode[0])
else:
logging.debug("BAZARR More than 5 episodes were added during this sync then we wont search for subtitles right now.")
2019-02-08 13:26:43 +00:00
def SonarrFormatAudioCodec(audioCodec):
if audioCodec == 'AC-3': return 'AC3'
if audioCodec == 'E-AC-3': return 'EAC3'
if audioCodec == 'MPEG Audio': return 'MP3'
return audioCodec
def SonarrFormatVideoCodec(videoCodec):
if videoCodec == 'x264' or videoCodec == 'AVC': return 'h264'
if videoCodec == 'x265' or videoCodec == 'HEVC': return 'h265'
if videoCodec.startswith('XviD'): return 'XviD'
if videoCodec.startswith('DivX'): return 'DivX'
if videoCodec == 'MPEG-1 Video': return 'Mpeg'
if videoCodec == 'MPEG-2 Video': return 'Mpeg2'
if videoCodec == 'MPEG-4 Video': return 'Mpeg4'
if videoCodec == 'VC-1': return 'VC1'
if videoCodec.endswith('VP6'): return 'VP6'
if videoCodec.endswith('VP7'): return 'VP7'
if videoCodec.endswith('VP8'): return 'VP8'
if videoCodec.endswith('VP9'): return 'VP9'
return videoCodec