Merge pull request #1101 from drikqlis/postprocess

Add variables to post-processing.
pull/1121/head
morpheus65535 4 years ago committed by GitHub
commit 98774f8931
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -219,6 +219,7 @@ def download_subtitle(path, language, audio_language, hi, forced, providers, pro
audio_language_code2 = alpha2_from_language(audio_language) audio_language_code2 = alpha2_from_language(audio_language)
audio_language_code3 = alpha3_from_language(audio_language) audio_language_code3 = alpha3_from_language(audio_language)
downloaded_path = subtitle.storage_path downloaded_path = subtitle.storage_path
subtitle_id = subtitle.id
if subtitle.language.hi: if subtitle.language.hi:
modifier_string = " HI" modifier_string = " HI"
elif subtitle.language.forced: elif subtitle.language.forced:
@ -239,6 +240,8 @@ def download_subtitle(path, language, audio_language, hi, forced, providers, pro
"table_episodes WHERE path = ?", "table_episodes WHERE path = ?",
(path_mappings.path_replace_reverse(path),), (path_mappings.path_replace_reverse(path),),
only_one=True) only_one=True)
series_id = episode_metadata['sonarrSeriesId']
episode_id = episode_metadata['sonarrEpisodeId']
sync_subtitles(video_path=path, srt_path=downloaded_path, sync_subtitles(video_path=path, srt_path=downloaded_path,
srt_lang=downloaded_language_code3, media_type=media_type, srt_lang=downloaded_language_code3, media_type=media_type,
percent_score=percent_score, percent_score=percent_score,
@ -248,6 +251,8 @@ def download_subtitle(path, language, audio_language, hi, forced, providers, pro
movie_metadata = database.execute("SELECT radarrId FROM table_movies WHERE path = ?", movie_metadata = database.execute("SELECT radarrId FROM table_movies WHERE path = ?",
(path_mappings.path_replace_reverse_movie(path),), (path_mappings.path_replace_reverse_movie(path),),
only_one=True) only_one=True)
series_id = ""
episode_id = movie_metadata['radarrId']
sync_subtitles(video_path=path, srt_path=downloaded_path, sync_subtitles(video_path=path, srt_path=downloaded_path,
srt_lang=downloaded_language_code3, media_type=media_type, srt_lang=downloaded_language_code3, media_type=media_type,
percent_score=percent_score, percent_score=percent_score,
@ -257,7 +262,7 @@ def download_subtitle(path, language, audio_language, hi, forced, providers, pro
command = pp_replace(postprocessing_cmd, path, downloaded_path, downloaded_language, command = pp_replace(postprocessing_cmd, path, downloaded_path, downloaded_language,
downloaded_language_code2, downloaded_language_code3, audio_language, downloaded_language_code2, downloaded_language_code3, audio_language,
audio_language_code2, audio_language_code3, subtitle.language.forced, audio_language_code2, audio_language_code3, subtitle.language.forced,
percent_score) percent_score, subtitle_id, downloaded_provider, series_id, episode_id)
if media_type == 'series': if media_type == 'series':
use_pp_threshold = settings.general.getboolean('use_postprocessing_threshold') use_pp_threshold = settings.general.getboolean('use_postprocessing_threshold')
@ -491,6 +496,7 @@ def manual_download_subtitle(path, language, audio_language, hi, forced, subtitl
audio_language_code2 = alpha2_from_language(audio_language) audio_language_code2 = alpha2_from_language(audio_language)
audio_language_code3 = alpha3_from_language(audio_language) audio_language_code3 = alpha3_from_language(audio_language)
downloaded_path = saved_subtitle.storage_path downloaded_path = saved_subtitle.storage_path
subtitle_id = subtitle.id
logging.debug('BAZARR Subtitles file saved to disk: ' + downloaded_path) logging.debug('BAZARR Subtitles file saved to disk: ' + downloaded_path)
if subtitle.language.hi: if subtitle.language.hi:
modifier_string = " HI" modifier_string = " HI"
@ -506,6 +512,8 @@ def manual_download_subtitle(path, language, audio_language, hi, forced, subtitl
"table_episodes WHERE path = ?", "table_episodes WHERE path = ?",
(path_mappings.path_replace_reverse(path),), (path_mappings.path_replace_reverse(path),),
only_one=True) only_one=True)
series_id = episode_metadata['sonarrSeriesId']
episode_id = episode_metadata['sonarrEpisodeId']
sync_subtitles(video_path=path, srt_path=downloaded_path, sync_subtitles(video_path=path, srt_path=downloaded_path,
srt_lang=downloaded_language_code3, media_type=media_type, srt_lang=downloaded_language_code3, media_type=media_type,
percent_score=score, percent_score=score,
@ -515,6 +523,8 @@ def manual_download_subtitle(path, language, audio_language, hi, forced, subtitl
movie_metadata = database.execute("SELECT radarrId FROM table_movies WHERE path = ?", movie_metadata = database.execute("SELECT radarrId FROM table_movies WHERE path = ?",
(path_mappings.path_replace_reverse_movie(path),), (path_mappings.path_replace_reverse_movie(path),),
only_one=True) only_one=True)
series_id = ""
episode_id = movie_metadata['radarrId']
sync_subtitles(video_path=path, srt_path=downloaded_path, sync_subtitles(video_path=path, srt_path=downloaded_path,
srt_lang=downloaded_language_code3, media_type=media_type, srt_lang=downloaded_language_code3, media_type=media_type,
percent_score=score, radarr_id=movie_metadata['radarrId']) percent_score=score, radarr_id=movie_metadata['radarrId'])
@ -524,7 +534,7 @@ def manual_download_subtitle(path, language, audio_language, hi, forced, subtitl
command = pp_replace(postprocessing_cmd, path, downloaded_path, downloaded_language, command = pp_replace(postprocessing_cmd, path, downloaded_path, downloaded_language,
downloaded_language_code2, downloaded_language_code3, audio_language, downloaded_language_code2, downloaded_language_code3, audio_language,
audio_language_code2, audio_language_code3, subtitle.language.forced, audio_language_code2, audio_language_code3, subtitle.language.forced,
percent_score) percent_score, subtitle_id, downloaded_provider, series_id, episode_id)
if media_type == 'series': if media_type == 'series':
use_pp_threshold = settings.general.getboolean('use_postprocessing_threshold') use_pp_threshold = settings.general.getboolean('use_postprocessing_threshold')
@ -629,6 +639,8 @@ def manual_upload_subtitle(path, language, forced, title, scene_name, media_type
episode_metadata = database.execute("SELECT sonarrSeriesId, sonarrEpisodeId FROM table_episodes WHERE path = ?", episode_metadata = database.execute("SELECT sonarrSeriesId, sonarrEpisodeId FROM table_episodes WHERE path = ?",
(path_mappings.path_replace_reverse(path),), (path_mappings.path_replace_reverse(path),),
only_one=True) only_one=True)
series_id = episode_metadata['sonarrSeriesId']
episode_id = episode_metadata['sonarrEpisodeId']
sync_subtitles(video_path=path, srt_path=subtitle_path, srt_lang=uploaded_language_code3, media_type=media_type, sync_subtitles(video_path=path, srt_path=subtitle_path, srt_lang=uploaded_language_code3, media_type=media_type,
percent_score=100, sonarr_series_id=episode_metadata['sonarrSeriesId'], percent_score=100, sonarr_series_id=episode_metadata['sonarrSeriesId'],
sonarr_episode_id=episode_metadata['sonarrEpisodeId']) sonarr_episode_id=episode_metadata['sonarrEpisodeId'])
@ -636,13 +648,15 @@ def manual_upload_subtitle(path, language, forced, title, scene_name, media_type
movie_metadata = database.execute("SELECT radarrId FROM table_movies WHERE path = ?", movie_metadata = database.execute("SELECT radarrId FROM table_movies WHERE path = ?",
(path_mappings.path_replace_reverse_movie(path),), (path_mappings.path_replace_reverse_movie(path),),
only_one=True) only_one=True)
series_id = ""
episode_id = movie_metadata['radarrId']
sync_subtitles(video_path=path, srt_path=subtitle_path, srt_lang=uploaded_language_code3, media_type=media_type, sync_subtitles(video_path=path, srt_path=subtitle_path, srt_lang=uploaded_language_code3, media_type=media_type,
percent_score=100, radarr_id=movie_metadata['radarrId']) percent_score=100, radarr_id=movie_metadata['radarrId'])
if use_postprocessing : if use_postprocessing :
command = pp_replace(postprocessing_cmd, path, subtitle_path, uploaded_language, command = pp_replace(postprocessing_cmd, path, subtitle_path, uploaded_language,
uploaded_language_code2, uploaded_language_code3, audio_language, uploaded_language_code2, uploaded_language_code3, audio_language,
audio_language_code2, audio_language_code3, forced, 100) audio_language_code2, audio_language_code3, forced, 100, "1", "manual", series_id, episode_id)
postprocessing(command, path) postprocessing(command, path)
if media_type == 'series': if media_type == 'series':

@ -95,7 +95,7 @@ class PathMappings:
path_mappings = PathMappings() path_mappings = PathMappings()
def pp_replace(pp_command, episode, subtitles, language, language_code2, language_code3, episode_language, episode_language_code2, episode_language_code3, forced, score): def pp_replace(pp_command, episode, subtitles, language, language_code2, language_code3, episode_language, episode_language_code2, episode_language_code3, forced, score, subtitle_id, provider, series_id, episode_id):
is_forced = ":forced" if forced else "" is_forced = ":forced" if forced else ""
is_forced_string = " forced" if forced else "" is_forced_string = " forced" if forced else ""
pp_command = pp_command.replace('{{directory}}', os.path.dirname(episode)) pp_command = pp_command.replace('{{directory}}', os.path.dirname(episode))
@ -109,6 +109,10 @@ def pp_replace(pp_command, episode, subtitles, language, language_code2, languag
pp_command = pp_command.replace('{{episode_language_code2}}', episode_language_code2) pp_command = pp_command.replace('{{episode_language_code2}}', episode_language_code2)
pp_command = pp_command.replace('{{episode_language_code3}}', episode_language_code3) pp_command = pp_command.replace('{{episode_language_code3}}', episode_language_code3)
pp_command = pp_command.replace('{{score}}', str(score)) pp_command = pp_command.replace('{{score}}', str(score))
pp_command = pp_command.replace('{{subtitle_id}}', str(subtitle_id))
pp_command = pp_command.replace('{{provider}}', str(provider))
pp_command = pp_command.replace('{{series_id}}', str(series_id))
pp_command = pp_command.replace('{{episode_id}}', str(episode_id))
return pp_command return pp_command

@ -582,6 +582,14 @@
<p>The 3-letter ISO-639 language code of the episode audio language.</p> <p>The 3-letter ISO-639 language code of the episode audio language.</p>
<b>&lbrace;&lbrace;score&rbrace;&rbrace;</b> <b>&lbrace;&lbrace;score&rbrace;&rbrace;</b>
<p>The score of the subtitles file.</p> <p>The score of the subtitles file.</p>
<b>&lbrace;&lbrace;subtitle_id&rbrace;&rbrace;</b>
<p>Provider ID of the subtitles file.</p>
<b>&lbrace;&lbrace;provider&rbrace;&rbrace;</b>
<p>Provider of the subtitles file.</p>
<b>&lbrace;&lbrace;series_id&rbrace;&rbrace;</b>
<p>Sonarr series ID. Empty if movie.</p>
<b>&lbrace;&lbrace;episode_id&rbrace;&rbrace;</b>
<p>Sonarr episode ID or Radarr movie ID.</p>
</div> </div>
</div> </div>
</div> </div>

Loading…
Cancel
Save