|
|
@ -228,7 +228,7 @@ class OpenSubtitlesComProvider(ProviderRetryMixin, Provider):
|
|
|
|
title_id = None
|
|
|
|
title_id = None
|
|
|
|
|
|
|
|
|
|
|
|
parameters = {'query': title.lower()}
|
|
|
|
parameters = {'query': title.lower()}
|
|
|
|
logging.debug(f'Searching using this title: {title}')
|
|
|
|
logger.debug(f'Searching using this title: {title}')
|
|
|
|
|
|
|
|
|
|
|
|
results = self.retry(
|
|
|
|
results = self.retry(
|
|
|
|
lambda: self.checked(
|
|
|
|
lambda: self.checked(
|
|
|
@ -259,7 +259,7 @@ class OpenSubtitlesComProvider(ProviderRetryMixin, Provider):
|
|
|
|
continue
|
|
|
|
continue
|
|
|
|
|
|
|
|
|
|
|
|
if title_id:
|
|
|
|
if title_id:
|
|
|
|
logging.debug(f'Found this title ID: {title_id}')
|
|
|
|
logger.debug(f'Found this title ID: {title_id}')
|
|
|
|
return self.sanitize_external_ids(title_id)
|
|
|
|
return self.sanitize_external_ids(title_id)
|
|
|
|
|
|
|
|
|
|
|
|
if not title_id:
|
|
|
|
if not title_id:
|
|
|
@ -269,7 +269,7 @@ class OpenSubtitlesComProvider(ProviderRetryMixin, Provider):
|
|
|
|
self.video = video
|
|
|
|
self.video = video
|
|
|
|
if self.use_hash:
|
|
|
|
if self.use_hash:
|
|
|
|
file_hash = self.video.hashes.get('opensubtitlescom')
|
|
|
|
file_hash = self.video.hashes.get('opensubtitlescom')
|
|
|
|
logging.debug(f'Searching using this hash: {hash}')
|
|
|
|
logger.debug(f'Searching using this hash: {file_hash}')
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
file_hash = None
|
|
|
|
file_hash = None
|
|
|
|
|
|
|
|
|
|
|
@ -294,7 +294,7 @@ class OpenSubtitlesComProvider(ProviderRetryMixin, Provider):
|
|
|
|
langs_list = sorted(list(set([to_opensubtitlescom(lang.basename).lower() for lang in languages])))
|
|
|
|
langs_list = sorted(list(set([to_opensubtitlescom(lang.basename).lower() for lang in languages])))
|
|
|
|
|
|
|
|
|
|
|
|
langs = ','.join(langs_list)
|
|
|
|
langs = ','.join(langs_list)
|
|
|
|
logging.debug(f'Searching for those languages: {langs}')
|
|
|
|
logger.debug(f'Searching for those languages: {langs}')
|
|
|
|
|
|
|
|
|
|
|
|
# query the server
|
|
|
|
# query the server
|
|
|
|
if isinstance(self.video, Episode):
|
|
|
|
if isinstance(self.video, Episode):
|
|
|
@ -344,18 +344,18 @@ class OpenSubtitlesComProvider(ProviderRetryMixin, Provider):
|
|
|
|
else: # not forced
|
|
|
|
else: # not forced
|
|
|
|
result['data'] = [x for x in result['data'] if not x['attributes']['foreign_parts_only']]
|
|
|
|
result['data'] = [x for x in result['data'] if not x['attributes']['foreign_parts_only']]
|
|
|
|
|
|
|
|
|
|
|
|
logging.debug(f"Query returned {len(result['data'])} subtitles")
|
|
|
|
logger.debug(f"Query returned {len(result['data'])} subtitles")
|
|
|
|
|
|
|
|
|
|
|
|
if len(result['data']):
|
|
|
|
if len(result['data']):
|
|
|
|
for item in result['data']:
|
|
|
|
for item in result['data']:
|
|
|
|
# ignore AI translated subtitles
|
|
|
|
# ignore AI translated subtitles
|
|
|
|
if 'ai_translated' in item['attributes'] and item['attributes']['ai_translated']:
|
|
|
|
if 'ai_translated' in item['attributes'] and item['attributes']['ai_translated']:
|
|
|
|
logging.debug("Skipping AI translated subtitles")
|
|
|
|
logger.debug("Skipping AI translated subtitles")
|
|
|
|
continue
|
|
|
|
continue
|
|
|
|
|
|
|
|
|
|
|
|
# ignore machine translated subtitles
|
|
|
|
# ignore machine translated subtitles
|
|
|
|
if 'machine_translated' in item['attributes'] and item['attributes']['machine_translated']:
|
|
|
|
if 'machine_translated' in item['attributes'] and item['attributes']['machine_translated']:
|
|
|
|
logging.debug("Skipping machine translated subtitles")
|
|
|
|
logger.debug("Skipping machine translated subtitles")
|
|
|
|
continue
|
|
|
|
continue
|
|
|
|
|
|
|
|
|
|
|
|
if 'season_number' in item['attributes']['feature_details']:
|
|
|
|
if 'season_number' in item['attributes']['feature_details']:
|
|
|
@ -440,7 +440,7 @@ class OpenSubtitlesComProvider(ProviderRetryMixin, Provider):
|
|
|
|
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
@staticmethod
|
|
|
|
def reset_token():
|
|
|
|
def reset_token():
|
|
|
|
logging.debug('Authentication failed: clearing cache and attempting to login.')
|
|
|
|
logger.debug('Authentication failed: clearing cache and attempting to login.')
|
|
|
|
region.delete("oscom_token")
|
|
|
|
region.delete("oscom_token")
|
|
|
|
return
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
|
@ -470,7 +470,7 @@ class OpenSubtitlesComProvider(ProviderRetryMixin, Provider):
|
|
|
|
except (ConnectionError, Timeout, ReadTimeout):
|
|
|
|
except (ConnectionError, Timeout, ReadTimeout):
|
|
|
|
raise ServiceUnavailable(f'Unknown Error, empty response: {response.status_code}: {response}')
|
|
|
|
raise ServiceUnavailable(f'Unknown Error, empty response: {response.status_code}: {response}')
|
|
|
|
except Exception:
|
|
|
|
except Exception:
|
|
|
|
logging.exception('Unhandled exception raised.')
|
|
|
|
logger.exception('Unhandled exception raised.')
|
|
|
|
raise ProviderError('Unhandled exception raised. Check log.')
|
|
|
|
raise ProviderError('Unhandled exception raised. Check log.')
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
status_code = response.status_code
|
|
|
|
status_code = response.status_code
|
|
|
@ -519,7 +519,7 @@ class OpenSubtitlesComProvider(ProviderRetryMixin, Provider):
|
|
|
|
log_request_response(response)
|
|
|
|
log_request_response(response)
|
|
|
|
raise TooManyRequests()
|
|
|
|
raise TooManyRequests()
|
|
|
|
elif status_code == 500:
|
|
|
|
elif status_code == 500:
|
|
|
|
logging.debug("Server side exception raised while downloading from opensubtitles.com website. They "
|
|
|
|
logger.debug("Server side exception raised while downloading from opensubtitles.com website. They "
|
|
|
|
"should mitigate this soon.")
|
|
|
|
"should mitigate this soon.")
|
|
|
|
return None
|
|
|
|
return None
|
|
|
|
elif status_code == 502:
|
|
|
|
elif status_code == 502:
|
|
|
@ -543,10 +543,10 @@ class OpenSubtitlesComProvider(ProviderRetryMixin, Provider):
|
|
|
|
|
|
|
|
|
|
|
|
if validate_content:
|
|
|
|
if validate_content:
|
|
|
|
if not hasattr(response, 'content'):
|
|
|
|
if not hasattr(response, 'content'):
|
|
|
|
logging.error('Download link returned no content attribute.')
|
|
|
|
logger.error('Download link returned no content attribute.')
|
|
|
|
return False
|
|
|
|
return False
|
|
|
|
elif not response.content:
|
|
|
|
elif not response.content:
|
|
|
|
logging.error(f'This download link returned empty content: {response.url}')
|
|
|
|
logger.error(f'This download link returned empty content: {response.url}')
|
|
|
|
return False
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
|
|
return response
|
|
|
|
return response
|
|
|
@ -566,13 +566,13 @@ def log_request_response(response, non_standard=True):
|
|
|
|
redacted_response_body['token'] = redacted_response_body['token'][:-8] + 8 * 'x'
|
|
|
|
redacted_response_body['token'] = redacted_response_body['token'][:-8] + 8 * 'x'
|
|
|
|
|
|
|
|
|
|
|
|
if non_standard:
|
|
|
|
if non_standard:
|
|
|
|
logging.debug("opensubtitlescom returned a non standard response. Logging request/response for debugging "
|
|
|
|
logger.debug("opensubtitlescom returned a non standard response. Logging request/response for debugging "
|
|
|
|
"purpose.")
|
|
|
|
"purpose.")
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
logging.debug("opensubtitlescom returned a standard response. Logging request/response for debugging purpose.")
|
|
|
|
logger.debug("opensubtitlescom returned a standard response. Logging request/response for debugging purpose.")
|
|
|
|
logging.debug(f"Request URL: {response.request.url}")
|
|
|
|
logger.debug(f"Request URL: {response.request.url}")
|
|
|
|
logging.debug(f"Request Headers: {redacted_request_headers}")
|
|
|
|
logger.debug(f"Request Headers: {redacted_request_headers}")
|
|
|
|
logging.debug(f"Request Body: {json.dumps(redacted_request_body)}")
|
|
|
|
logger.debug(f"Request Body: {json.dumps(redacted_request_body)}")
|
|
|
|
logging.debug(f"Response Status Code: {response.status_code}")
|
|
|
|
logger.debug(f"Response Status Code: {response.status_code}")
|
|
|
|
logging.debug(f"Response Headers: {response.headers}")
|
|
|
|
logger.debug(f"Response Headers: {response.headers}")
|
|
|
|
logging.debug(f"Response Body: {json.dumps(redacted_response_body)}")
|
|
|
|
logger.debug(f"Response Body: {json.dumps(redacted_response_body)}")
|
|
|
|