From 41db7a09c3fb7ff434354df767b96475c90af515 Mon Sep 17 00:00:00 2001 From: Mor Sela Date: Sat, 8 Apr 2017 10:18:02 +0300 Subject: [PATCH] Fixed broken download due to site changes and added some future changes protection (#52) --- addon.xml | 4 +- changelog.txt | 3 ++ resources/lib/TorecSubtitlesDownloader.py | 58 ++++++++++++++++++----- 3 files changed, 52 insertions(+), 13 deletions(-) diff --git a/addon.xml b/addon.xml index 9e4afe5..7d51a73 100644 --- a/addon.xml +++ b/addon.xml @@ -1,7 +1,7 @@ @@ -13,7 +13,7 @@ Kodi/XBMC Torec Subtitles allows for downloading hebrew subtitles from the Israeli site Torec.net Search and download various hebrew subtitles from the Israeli subtitles site Torec.net. - https://github.com/slmosl/service.subtitles.Torec + https://github.com/XBMCil/service.subtitles.torec GNU GENERAL PUBLIC LICENSE. Version 2, June 1991 diff --git a/changelog.txt b/changelog.txt index 6fa4987..3b23fe7 100644 --- a/changelog.txt +++ b/changelog.txt @@ -1,3 +1,6 @@ +1.3.1 +- Fixed broken download due to site changes and added some future changes protection + 1.3.0 - Added fake token generation support - download speed should much improve (@yosi-dediashvili) - Improved Checking item's media type (@burekas7) diff --git a/resources/lib/TorecSubtitlesDownloader.py b/resources/lib/TorecSubtitlesDownloader.py index 83ef3bc..ddc37f8 100644 --- a/resources/lib/TorecSubtitlesDownloader.py +++ b/resources/lib/TorecSubtitlesDownloader.py @@ -113,14 +113,18 @@ def login(self): return username in content class TorecGuestTokenGenerator(): - def __init__(self, sub_id): + def __init__(self, sub_id, handle_daylight_saving_skew): self.sub_id = sub_id + self.handle_daylight_saving_skew = handle_daylight_saving_skew def generate_ticket(self): return self._gen_fake_encoded_ticket(self.sub_id, 90) def _gen_plain_ticket(self, sub_id, secs_ago): t = datetime.datetime.now() - datetime.timedelta(seconds=secs_ago) + if self.handle_daylight_saving_skew: + t -= datetime.timedelta(hours = 1) + st = t.strftime("%m/%d/%Y %-I:%M:%S %p") st = re.sub("(^|/| )0", r"\1", st) return "{}_sub{}".format(st, sub_id) @@ -131,6 +135,14 @@ def _encode_ticket(self, plain_ticket): for p, o in zip(plain_ticket, itertools.cycle("imet")) ) + def _decode_ticket(self, ticket): + split_ticket = re.findall('..', ticket) + + return ''.join( + chr(int(p, 16) - ord(o)) + for p, o in zip(split_ticket, itertools.cycle("imet")) + ) + def _gen_fake_encoded_ticket(self, sub_id, secs_ago): return self._encode_ticket(self._gen_plain_ticket(sub_id, secs_ago)) @@ -151,7 +163,7 @@ def __init__(self): def _build_default_cookie(self, sub_id): current_time = datetime.datetime.now().strftime("%m/%d/%Y+%I:%M:%S+%p") return self.DEFAULT_COOKIE % { - "screen_width": 1440, + "screen_width": 1680, "subId": sub_id, "current_datetime": current_time } @@ -255,10 +267,7 @@ def _confirm_download_code(self, sub_id, option_id): response = self.opener.open("%s/ajax/sub/t7/guest_dl_code.asp" % self.BASE_URL, urllib.urlencode(params)) response_data = response.read() - def get_download_link(self, sub_id, option_id): - self._confirm_download_code(sub_id, option_id) - - guest_token = TorecGuestTokenGenerator(sub_id).generate_ticket() + def _try_get_download_link(self, sub_id, option_id, guest_token): encoded_params = urllib.urlencode({ "sub_id": sub_id, "code": option_id, @@ -267,23 +276,50 @@ def get_download_link(self, sub_id, option_id): "timewaited": 13 }) + response = self.opener.open("%s/ajax/sub/t7/downloadun.asp" % self.BASE_URL, encoded_params) + + download_link = response.read() + if download_link and "sdls.asp" in download_link: + return download_link + else: + return None + + def _get_download_link_with_regular_token(self, sub_id, option_id): + guest_token = self._request_subtitle(sub_id) + download_link = None waited_msec = 0.0 # Torec website may delay download up to 13 seconds while (not xbmc.abortRequested) and (waited_msec < self.MAXIMUM_WAIT_TIME_MSEC): - response = self.opener.open("%s/ajax/sub/t7/downloadun.asp" % self.BASE_URL, encoded_params) - download_link = response.read() - - if download_link and "sdls.asp" in download_link: + download_link = self._try_get_download_link(sub_id, option_id, guest_token) + if download_link: break - + xbmc.sleep(500) waited_msec += 500 log(__name__, "received link after sleeping %f seconds" % (waited_msec / 1000.0)) return download_link + + def get_download_link(self, sub_id, option_id): + self._confirm_download_code(sub_id, option_id) + + log(__name__, "trying to retrieve download link with skewed generated guest token") + generated_time_skewed_guest_token = TorecGuestTokenGenerator(sub_id, True).generate_ticket() + download_link = self._try_get_download_link(sub_id, option_id, generated_time_skewed_guest_token) + if download_link: + return download_link + + log(__name__, "trying to retrieve download link with generated guest token") + generated_guest_token = TorecGuestTokenGenerator(sub_id, False).generate_ticket() + download_link = self._try_get_download_link(sub_id, option_id, generated_guest_token) + if download_link: + return download_link + + log(__name__, "trying to retrieve download link with guest token request") + return self._get_download_link_with_regular_token(sub_id, option_id) def download(self, download_link):