From 94063db43e6eb02db71c997565039314e4a2fa3c Mon Sep 17 00:00:00 2001 From: garvinob Date: Sun, 24 Aug 2014 00:19:17 +0100 Subject: [PATCH 01/12] Fixed result content for Season Pack results Added an extra check into the snatchEpisode method so that the result.content data for a required torrent is always downloaded if needed --- sickbeard/search.py | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/sickbeard/search.py b/sickbeard/search.py index 3a6adc13..0978570c 100644 --- a/sickbeard/search.py +++ b/sickbeard/search.py @@ -129,6 +129,14 @@ def snatchEpisode(result, endStatus=SNATCHED): if sickbeard.TORRENT_METHOD == "blackhole": dlResult = _downloadResult(result) else: + # make sure we have the torrent file content + if not result.content: + if not result.url.startswith('magnet'): + result.content = result.provider.getURL(result.url) + if not result.content: + logger.log( + u"Torrent content failed to download from " + result.url, logger.ERROR + ) # Snatches torrent with client client = clients.getClientIstance(sickbeard.TORRENT_METHOD)() dlResult = client.sendTORRENT(result) From dce55b3dac1659337847dd05dec304508ccc4999 Mon Sep 17 00:00:00 2001 From: garvinob Date: Sun, 24 Aug 2014 18:47:06 +0100 Subject: [PATCH 02/12] Renamed bestSeasonNZB to bestSeasonResult bestSeasonNZB is confusing in this context we are dealing with results which can be NZBs or Torrents --- sickbeard/search.py | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/sickbeard/search.py b/sickbeard/search.py index 0978570c..0668c216 100644 --- a/sickbeard/search.py +++ b/sickbeard/search.py @@ -485,9 +485,9 @@ def searchProviders(show, season, episodes, manualSearch=False): anyQualities, bestQualities = Quality.splitQuality(show.quality) # pick the best season NZB - bestSeasonNZB = None + bestSeasonResult = None if SEASON_RESULT in foundResults[curProvider.name]: - bestSeasonNZB = pickBestResult(foundResults[curProvider.name][SEASON_RESULT], show, + bestSeasonResult = pickBestResult(foundResults[curProvider.name][SEASON_RESULT], show, anyQualities + bestQualities) highest_quality_overall = 0 @@ -499,12 +499,12 @@ def searchProviders(show, season, episodes, manualSearch=False): logger.DEBUG) # see if every episode is wanted - if bestSeasonNZB: + if bestSeasonResult: # get the quality of the season nzb - seasonQual = bestSeasonNZB.quality + seasonQual = bestSeasonResult.quality logger.log( - u"The quality of the season " + bestSeasonNZB.provider.providerType + " is " + Quality.qualityStrings[ + u"The quality of the season " + bestSeasonResult.provider.providerType + " is " + Quality.qualityStrings[ seasonQual], logger.DEBUG) myDB = db.DBConnection() @@ -522,28 +522,28 @@ def searchProviders(show, season, episodes, manualSearch=False): anyWanted = True # if we need every ep in the season and there's nothing better then just download this and be done with it (unless single episodes are preferred) - if allWanted and bestSeasonNZB.quality == highest_quality_overall: + if allWanted and bestSeasonResult.quality == highest_quality_overall: logger.log( - u"Every ep in this season is needed, downloading the whole " + bestSeasonNZB.provider.providerType + " " + bestSeasonNZB.name) + u"Every ep in this season is needed, downloading the whole " + bestSeasonResult.provider.providerType + " " + bestSeasonResult.name) epObjs = [] for curEpNum in allEps: epObjs.append(show.getEpisode(season, curEpNum)) - bestSeasonNZB.episodes = epObjs + bestSeasonResult.episodes = epObjs - return [bestSeasonNZB] + return [bestSeasonResult] elif not anyWanted: logger.log( - u"No eps from this season are wanted at this quality, ignoring the result of " + bestSeasonNZB.name, + u"No eps from this season are wanted at this quality, ignoring the result of " + bestSeasonResult.name, logger.DEBUG) else: - if bestSeasonNZB.provider.providerType == GenericProvider.NZB: + if bestSeasonResult.provider.providerType == GenericProvider.NZB: logger.log(u"Breaking apart the NZB and adding the individual ones to our results", logger.DEBUG) # if not, break it apart and add them as the lowest priority results - individualResults = nzbSplitter.splitResult(bestSeasonNZB) + individualResults = nzbSplitter.splitResult(bestSeasonResult) individualResults = filter( lambda x: show_name_helpers.filterBadReleases(x.name) and x.show == show, individualResults) @@ -568,13 +568,13 @@ def searchProviders(show, season, episodes, manualSearch=False): epObjs = [] for curEpNum in allEps: epObjs.append(show.getEpisode(season, curEpNum)) - bestSeasonNZB.episodes = epObjs + bestSeasonResult.episodes = epObjs epNum = MULTI_EP_RESULT if epNum in foundResults[curProvider.name]: - foundResults[curProvider.name][epNum].append(bestSeasonNZB) + foundResults[curProvider.name][epNum].append(bestSeasonResult) else: - foundResults[curProvider.name][epNum] = [bestSeasonNZB] + foundResults[curProvider.name][epNum] = [bestSeasonResult] # go through multi-ep results and see if we really want them or not, get rid of the rest multiResults = {} From 7af333e1f7687cec831d7f2991ca0d52300e8fe8 Mon Sep 17 00:00:00 2001 From: Adam Date: Mon, 25 Aug 2014 13:37:55 +0800 Subject: [PATCH 03/12] Fix sorting on mass update page --- gui/slick/interfaces/default/manage.tmpl | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/gui/slick/interfaces/default/manage.tmpl b/gui/slick/interfaces/default/manage.tmpl index 71e3ae2c..64882eca 100644 --- a/gui/slick/interfaces/default/manage.tmpl +++ b/gui/slick/interfaces/default/manage.tmpl @@ -43,28 +43,31 @@ textExtraction: { 2: function(node) { return \$(node).find("span").text().toLowerCase(); }, 3: function(node) { return \$(node).find("img").attr("alt"); }, - 4: function(node) { return \$(node).find("img").attr("alt"); } + 4: function(node) { return \$(node).find("img").attr("alt"); }, + 5: function(node) { return \$(node).find("img").attr("alt"); }, + 6: function(node) { return \$(node).find("img").attr("alt"); }, + 7: function(node) { return \$(node).find("img").attr("alt"); } }, widgets: ['zebra'], headers: { 0: { sorter: false}, 1: { sorter: 'showNames'}, 2: { sorter: 'quality'}, - 3: { sorter: 'flatfold'}, - 4: { sorter: 'paused'}, - 5: { sorter: 'status'}, - 6: { sorter: false}, - 7: { sorter: false}, - 8: { sorter: false}, + 3: { sorter: true}, + 4: { sorter: true}, + 5: { sorter: true}, + 6: { sorter: true}, + 7: { sorter: true}, + 8: { sorter: true}, 9: { sorter: false}, 10: { sorter: false}, 11: { sorter: false}, 12: { sorter: false} -#if $sickbeard.USE_SUBTITLES +#if $sickbeard.USE_SUBTITLES , 13: { sorter: false} -#end if +#end if } - }); + }); }); //--> From 6b8a22898b6a74409413fe1dce5b797bf58dfdd2 Mon Sep 17 00:00:00 2001 From: Adam Date: Mon, 25 Aug 2014 14:54:22 +0800 Subject: [PATCH 04/12] Fix ABD shows manual and backlog searches --- sickbeard/name_parser/parser.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sickbeard/name_parser/parser.py b/sickbeard/name_parser/parser.py index 9ed3c0f3..7ac1de10 100644 --- a/sickbeard/name_parser/parser.py +++ b/sickbeard/name_parser/parser.py @@ -570,7 +570,7 @@ class ParseResult(object): @property def is_air_by_date(self): - if self.season_number == None and len(self.episode_numbers) == 0 and self.air_date: + if self.air_date: return True return False From a38229d04feaab2283edbfa6f77dcddc7576ed41 Mon Sep 17 00:00:00 2001 From: Adam Date: Mon, 25 Aug 2014 15:39:21 +0800 Subject: [PATCH 05/12] Change minimum backlog frequency to a more acceptable value --- sickbeard/__init__.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sickbeard/__init__.py b/sickbeard/__init__.py index 00621f53..c9390ac2 100755 --- a/sickbeard/__init__.py +++ b/sickbeard/__init__.py @@ -195,7 +195,7 @@ DAILYSEARCH_STARTUP = False BACKLOG_STARTUP = False MIN_AUTOPOSTPROCESSER_FREQUENCY = 1 -MIN_BACKLOG_FREQUENCY = 10 +MIN_BACKLOG_FREQUENCY = 1440 MIN_DAILYSEARCH_FREQUENCY = 10 MIN_UPDATE_FREQUENCY = 1 DEFAULT_AUTOPOSTPROCESSER_FREQUENCY = 10 From 13bef2b92d5deebf1afe795ca7f1f94818f902d6 Mon Sep 17 00:00:00 2001 From: Adam Date: Mon, 25 Aug 2014 17:35:53 +0800 Subject: [PATCH 06/12] Fix for torrentbytes provider where torrentid is <6 characters long --- sickbeard/providers/torrentbytes.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sickbeard/providers/torrentbytes.py b/sickbeard/providers/torrentbytes.py index e0013808..d8f646cb 100644 --- a/sickbeard/providers/torrentbytes.py +++ b/sickbeard/providers/torrentbytes.py @@ -184,7 +184,7 @@ class TorrentBytesProvider(generic.TorrentProvider): link = cells[1].find('a', attrs={'class': 'index'}) full_id = link['href'].replace('details.php?id=', '') - torrent_id = full_id[:6] + torrent_id = full_id.split("&")[0] try: if link.has_key('title'): From f43c214069df734a2f5688b277b0b3e02a6d0991 Mon Sep 17 00:00:00 2001 From: Adam Date: Mon, 25 Aug 2014 23:55:16 +0800 Subject: [PATCH 07/12] Fixes rejection of invalid torrent files --- sickbeard/providers/generic.py | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/sickbeard/providers/generic.py b/sickbeard/providers/generic.py index 2f82e811..6241e2a8 100644 --- a/sickbeard/providers/generic.py +++ b/sickbeard/providers/generic.py @@ -166,7 +166,11 @@ class GenericProvider: else: logger.log(u"Saved result to " + filename, logger.MESSAGE) - return self._verify_download(filename) + if self._verify_download(filename): + return True + + logger.log(u"Failed to download result", logger.ERROR) + return False def _verify_download(self, file_name=None): """ @@ -182,9 +186,11 @@ class GenericProvider: parser.stream._input.close() except: pass - if mime_type != 'application/x-bittorrent': - logger.log(u"Result is not a valid torrent file", logger.WARNING) - return False + if mime_type == 'application/x-bittorrent': + return True + + logger.log(u"Result is not a valid torrent file", logger.WARNING) + return False return True From 4739ab12ae442cbad1090bc5a57c95b160c7bf7b Mon Sep 17 00:00:00 2001 From: echel0n Date: Mon, 25 Aug 2014 23:09:13 -0700 Subject: [PATCH 08/12] Added www.kickmirror.com to list of urls to try --- sickbeard/providers/kat.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sickbeard/providers/kat.py b/sickbeard/providers/kat.py index 1f3273cc..a24eead5 100644 --- a/sickbeard/providers/kat.py +++ b/sickbeard/providers/kat.py @@ -61,7 +61,7 @@ class KATProvider(generic.TorrentProvider): self.cache = KATCache(self) - self.urls = ['http://kickass.to/', 'http://katproxy.com/'] + self.urls = ['http://kickass.to/', 'http://katproxy.com/', 'http://www.kickmirror.com'] self.url = None def isEnabled(self): From b03ffa231d26990af685acd6c20dac80631e84aa Mon Sep 17 00:00:00 2001 From: echel0n Date: Tue, 26 Aug 2014 07:31:57 -0700 Subject: [PATCH 09/12] Possible fix for incorrect show matches --- sickbeard/properFinder.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sickbeard/properFinder.py b/sickbeard/properFinder.py index a707aaee..d4911c6a 100644 --- a/sickbeard/properFinder.py +++ b/sickbeard/properFinder.py @@ -107,7 +107,7 @@ class ProperFinder(): for curProper in sortedPropers: try: - myParser = NameParser(False, showObj=curProper.show) + myParser = NameParser(False) parse_result = myParser.parse(curProper.name) except InvalidNameException: logger.log(u"Unable to parse the filename " + curProper.name + " into a valid episode", logger.DEBUG) From 25f57b26fecf6fb969a77a950ab5d02fc9fd4c81 Mon Sep 17 00:00:00 2001 From: RoostayFish Date: Tue, 26 Aug 2014 15:44:15 +0100 Subject: [PATCH 10/12] Added indexerid to CMD_Show(ApiCall) --- sickbeard/webapi.py | 1 + 1 file changed, 1 insertion(+) diff --git a/sickbeard/webapi.py b/sickbeard/webapi.py index 70a1c911..f6260440 100644 --- a/sickbeard/webapi.py +++ b/sickbeard/webapi.py @@ -1750,6 +1750,7 @@ class CMD_Show(ApiCall): showDict["anime"] = showObj.anime #clean up tvdb horrible airs field showDict["airs"] = str(showObj.airs).replace('am', ' AM').replace('pm', ' PM').replace(' ', ' ') + showDict["indexerid"] = self.indexerid showDict["tvrage_id"] = helpers.mapIndexersToShow(showObj)[2] showDict["tvrage_name"] = showObj.name showDict["network"] = showObj.network From efd11a6c0884bbc82e3fc2c1e27924185978db8c Mon Sep 17 00:00:00 2001 From: Matthew Haughton <3flex@users.noreply.github.com> Date: Tue, 26 Aug 2014 19:19:34 -0400 Subject: [PATCH 11/12] notifiers/libnotify: fix syntax error from #624 Prior to this got error 'too many values to unpack' when updating and libnotify notifications were enabled. --- sickbeard/notifiers/libnotify.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/sickbeard/notifiers/libnotify.py b/sickbeard/notifiers/libnotify.py index 5f8b96f9..9984bdce 100644 --- a/sickbeard/notifiers/libnotify.py +++ b/sickbeard/notifiers/libnotify.py @@ -95,7 +95,8 @@ class LibnotifyNotifier: def notify_git_update(self, new_version = "??"): if sickbeard.USE_LIBNOTIFY: - update_text=common.notifyStrings[common.NOTIFY_GIT_UPDATE_TEXT], title=common.notifyStrings[common.NOTIFY_GIT_UPDATE] + update_text=common.notifyStrings[common.NOTIFY_GIT_UPDATE_TEXT] + title=common.notifyStrings[common.NOTIFY_GIT_UPDATE] self._notify(title, update_text + new_version) def test_notify(self): From ce52dc8333d469bda89ce69160eebbb53f653dda Mon Sep 17 00:00:00 2001 From: whiethatguy Date: Wed, 27 Aug 2014 10:14:13 -0300 Subject: [PATCH 12/12] Update bitsoup.py - new table format Table that lists torrents has changed, and the download link is on third column --- sickbeard/providers/bitsoup.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sickbeard/providers/bitsoup.py b/sickbeard/providers/bitsoup.py index aaf50a92..2500353a 100644 --- a/sickbeard/providers/bitsoup.py +++ b/sickbeard/providers/bitsoup.py @@ -188,7 +188,7 @@ class BitSoupProvider(generic.TorrentProvider): cells = result.find_all('td') link = cells[1].find('a') - download_url = self.urls['download'] % cells[3].find('a')['href'] + download_url = self.urls['download'] % cells[2].find('a')['href'] id = link['href'] id = id.replace('details.php?id=','')