From e337bf89242aba74b521e50d77e51f10a707197a Mon Sep 17 00:00:00 2001 From: moparisthebest Date: Tue, 24 Feb 2015 01:02:29 -0500 Subject: [PATCH] Add BinSearch to NZB Providers --- gui/slick/images/providers/binsearch.png | Bin 0 -> 340 bytes sickbeard/__init__.py | 6 +- sickbeard/providers/__init__.py | 1 + sickbeard/providers/binsearch.py | 119 +++++++++++++++++++++++ 4 files changed, 124 insertions(+), 2 deletions(-) create mode 100644 gui/slick/images/providers/binsearch.png create mode 100644 sickbeard/providers/binsearch.py diff --git a/gui/slick/images/providers/binsearch.png b/gui/slick/images/providers/binsearch.png new file mode 100644 index 0000000000000000000000000000000000000000..890ff858119a95e9841fc9bb8f38bd5989d850f8 GIT binary patch literal 340 zcmeAS@N?(olHy`uVBq!ia0vp^0wBx*Bp9q_EZ7UASkfJR9T^xl_H+M9WCijWi-X*q z7}lMWc?skwBzpw;GB8xBF)%c=FfjZA3N^f7U???UV0e`PGJ=6YykO3*KpUV0Q +# +# This file is part of Sick Beard. +# +# Sick Beard is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Sick Beard is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Sick Beard. If not, see . +import urllib +import re +import time + +import sickbeard + +import generic + +from sickbeard import logger +from sickbeard import tvcache +from sickbeard.exceptions import AuthException + +class BinSearchProvider(generic.NZBProvider): + def __init__(self): + generic.NZBProvider.__init__(self, "BinSearch") + self.enabled = False + self.cache = BinSearchCache(self) + self.urls = {'base_url': 'https://www.binsearch.info/'} + self.url = self.urls['base_url'] + + def isEnabled(self): + return self.enabled + +class BinSearchCache(tvcache.TVCache): + def __init__(self, provider): + tvcache.TVCache.__init__(self, provider) + # only poll Binsearch every 30 minutes max + self.minTime = 30 + + # compile and save our regular expressions + + # this pulls the title from the URL in the description + self.descTitleStart = re.compile('^.*https?://www\.binsearch\.info/.b=') + self.descTitleEnd = re.compile('&.*$') + + # these clean up the horrible mess of a title if the above fail + self.titleCleaners = [ + re.compile('.?yEnc.?\(\d+/\d+\)$'), + re.compile(' \[\d+/\d+\] '), + ] + + def _get_title_and_url(self, item): + """ + Retrieves the title and URL data from the item XML node + + item: An elementtree.ElementTree element representing the tag of the RSS feed + + Returns: A tuple containing two strings representing title and URL respectively + """ + + title = item.get('description') + if title: + title = u'' + title + if self.descTitleStart.match(title): + title = self.descTitleStart.sub('', title) + title = self.descTitleEnd.sub('', title) + title = title.replace('+', '.') + else: + # just use the entire title, looks hard/impossible to parse + title = item.get('title') + if title: + for titleCleaner in self.titleCleaners: + title = titleCleaner.sub('', title) + + url = item.get('link') + if url: + url = url.replace('&', '&') + + return (title, url) + + def updateCache(self): + # check if we should update + if not self.shouldUpdate(): + return + + # clear cache + self._clearCache() + + # set updated + self.setLastUpdate() + + cl = [] + for group in ['alt.binaries.boneless','alt.binaries.misc','alt.binaries.hdtv','alt.binaries.hdtv.x264','alt.binaries.tv','alt.binaries.tvseries']: + url = self.provider.url + 'rss.php?' + urlArgs = {'max': 1000,'g': group} + + url += urllib.urlencode(urlArgs) + + logger.log(u"BinSearch cache update URL: " + url, logger.DEBUG) + + for item in self.getRSSFeed(url)['entries'] or []: + ci = self._parseItem(item) + if ci is not None: + cl.append(ci) + + if len(cl) > 0: + myDB = self._getDB() + myDB.mass_action(cl) + + def _checkAuth(self, data): + return data if data['feed'] and data['feed']['title'] != 'Invalid Link' else None + +provider = BinSearchProvider()