diff --git a/sickbeard/__init__.py b/sickbeard/__init__.py index d981bed6..73f2066a 100644 --- a/sickbeard/__init__.py +++ b/sickbeard/__init__.py @@ -50,6 +50,8 @@ from sickbeard.databases import mainDB, cache_db, failed_db from lib.configobj import ConfigObj +import xml.etree.ElementTree as ElementTree + invoked_command = None PID = None @@ -135,6 +137,7 @@ ROOT_DIRS = None UPDATE_SHOWS_ON_START = None SORT_ARTICLE = None DEBUG = False +CLEAR_CACHE = None USE_LISTVIEW = None METADATA_XBMC = None @@ -521,7 +524,7 @@ def initialize(consoleLogging=True): USE_SYNOLOGYNOTIFIER, SYNOLOGYNOTIFIER_NOTIFY_ONSNATCH, SYNOLOGYNOTIFIER_NOTIFY_ONDOWNLOAD, SYNOLOGYNOTIFIER_NOTIFY_ONSUBTITLEDOWNLOAD, \ USE_EMAIL, EMAIL_HOST, EMAIL_PORT, EMAIL_TLS, EMAIL_USER, EMAIL_PASSWORD, EMAIL_FROM, EMAIL_NOTIFY_ONSNATCH, EMAIL_NOTIFY_ONDOWNLOAD, EMAIL_NOTIFY_ONSUBTITLEDOWNLOAD, EMAIL_LIST, \ USE_LISTVIEW, METADATA_XBMC, METADATA_XBMC_12PLUS, METADATA_MEDIABROWSER, METADATA_PS3, metadata_provider_dict, \ - NEWZBIN, NEWZBIN_USERNAME, NEWZBIN_PASSWORD, GIT_PATH, MOVE_ASSOCIATED_FILES, \ + NEWZBIN, NEWZBIN_USERNAME, NEWZBIN_PASSWORD, GIT_PATH, MOVE_ASSOCIATED_FILES, CLEAR_CACHE, \ GUI_NAME, HOME_LAYOUT, HISTORY_LAYOUT, DISPLAY_SHOW_SPECIALS, COMING_EPS_LAYOUT, COMING_EPS_SORT, COMING_EPS_DISPLAY_PAUSED, COMING_EPS_MISSED_RANGE, DATE_PRESET, TIME_PRESET, TIME_PRESET_W_SECONDS, \ METADATA_WDTV, METADATA_TIVO, METADATA_MEDE8ER, IGNORE_WORDS, CALENDAR_UNPROTECTED, CREATE_MISSING_SHOW_DIRS, \ ADD_SHOWS_WO_DIR, USE_SUBTITLES, SUBTITLES_LANGUAGES, SUBTITLES_DIR, SUBTITLES_SERVICES_LIST, SUBTITLES_SERVICES_ENABLED, SUBTITLES_HISTORY, SUBTITLES_FINDER_FREQUENCY, subtitlesFinderScheduler, \ @@ -1123,6 +1126,17 @@ def initialize(consoleLogging=True): showList = [] loadingShowList = {} + try: + url = 'http://raw.github.com/echel0n/sickrage-init/master/settings.ini' + clear_cache = ElementTree.XML(helpers.getURL(url)).find('cache/clear').text + CLEAR_CACHE = check_setting_str(CFG, 'General', 'clear_cache', '') + if CLEAR_CACHE != clear_cache: + for curProvider in [x for x in providers.sortedProviderList() if x.isActive()]: + curProvider.cache._clearCache() + CLEAR_CACHE = clear_cache + save_config() + except:pass + __INITIALIZED__ = True return True @@ -1442,6 +1456,8 @@ def save_config(): new_config['General']['ignore_words'] = IGNORE_WORDS new_config['General']['calendar_unprotected'] = int(CALENDAR_UNPROTECTED) + new_config['General']['clear_cache'] = CLEAR_CACHE + new_config['Blackhole'] = {} new_config['Blackhole']['nzb_dir'] = NZB_DIR new_config['Blackhole']['torrent_dir'] = TORRENT_DIR diff --git a/sickbeard/clients/transmission.py b/sickbeard/clients/transmission.py index 82a87cd2..6f3e0e22 100644 --- a/sickbeard/clients/transmission.py +++ b/sickbeard/clients/transmission.py @@ -85,12 +85,12 @@ class TransmissionAPI(GenericClient): ratio = result.ratio elif sickbeard.TORRENT_RATIO: ratio = sickbeard.TORRENT_RATIO - - try: - float(ratio) - except ValueError: - logger.log(self.name + u': Invalid Ratio. "' + ratio + u'" is not a number', logger.ERROR) - return False + if ratio: + try: + float(ratio) + except ValueError: + logger.log(self.name + u': Invalid Ratio. "' + ratio + u'" is not a number', logger.ERROR) + return False torrent_id = self._get_torrent_hash(result) diff --git a/sickbeard/helpers.py b/sickbeard/helpers.py index 5726e90c..751fa59a 100644 --- a/sickbeard/helpers.py +++ b/sickbeard/helpers.py @@ -212,10 +212,11 @@ def getURL(url, post_data=None, headers=None, params=None, timeout=30, json=Fals logger.log(u"Connection timed out " + str(e.message) + " while loading URL " + url, logger.WARNING) return None - if json: - return r.json() if r.ok else None + if r.ok: + if json: + return r.json() - return r.content if r.ok else None + return r.content def _remove_file_failed(file): @@ -284,7 +285,7 @@ def makeDir(path): return True -def searchDBForShow(regShowName): +def searchDBForShow(regShowName, log=False): showNames = [re.sub('[. -]', ' ', regShowName)] myDB = db.DBConnection() @@ -303,17 +304,20 @@ def searchDBForShow(regShowName): # if we didn't get exactly one result then try again with the year stripped off if possible match = re.match(yearRegex, showName) if match and match.group(1): - logger.log(u"Unable to match original name but trying to manually strip and specify show year", - logger.DEBUG) + if log: + logger.log(u"Unable to match original name but trying to manually strip and specify show year", + logger.DEBUG) sqlResults = myDB.select( "SELECT * FROM tv_shows WHERE (show_name LIKE ?) AND startyear = ?", [match.group(1) + '%', match.group(3)]) if len(sqlResults) == 0: - logger.log(u"Unable to match a record in the DB for " + showName, logger.DEBUG) + if log: + logger.log(u"Unable to match a record in the DB for " + showName, logger.DEBUG) continue elif len(sqlResults) > 1: - logger.log(u"Multiple results for " + showName + " in the DB, unable to match show name", logger.DEBUG) + if log: + logger.log(u"Multiple results for " + showName + " in the DB, unable to match show name", logger.DEBUG) continue else: return (int(sqlResults[0]["indexer_id"]), sqlResults[0]["show_name"]) diff --git a/sickbeard/name_parser/parser.py b/sickbeard/name_parser/parser.py index d2dae022..aacad9f5 100644 --- a/sickbeard/name_parser/parser.py +++ b/sickbeard/name_parser/parser.py @@ -377,7 +377,10 @@ class ParseResult(object): if self.season_number == None: return self # can't work without a season if len(self.episode_numbers) == 0: return self # need at least one episode - self.show = helpers.get_show_by_name(self.series_name) + showResult = helpers.searchDBForShow(self.series_name) + if showResult: + self.show = helpers.findCertainShow(sickbeard.showList, int(showResult[0])) + if not self.show: return self diff --git a/sickbeard/notifiers/boxcar2.py b/sickbeard/notifiers/boxcar2.py index b41a9d1f..5f3cec4d 100755 --- a/sickbeard/notifiers/boxcar2.py +++ b/sickbeard/notifiers/boxcar2.py @@ -52,9 +52,9 @@ class Boxcar2Notifier: data = urllib.urlencode({ 'user_credentials': accesstoken, - 'notification[title]': "SickRage : " + title, + 'notification[title]': "SickRage : " + title + ' ' + msg, 'notification[long_message]': msg, - 'notification[sound]': "bird-1" + 'notification[sound]': "success" }) # send the request to boxcar2 diff --git a/sickbeard/providers/scc.py b/sickbeard/providers/scc.py index 733418dc..5f907489 100644 --- a/sickbeard/providers/scc.py +++ b/sickbeard/providers/scc.py @@ -142,7 +142,7 @@ class SCCProvider(generic.TorrentProvider): return [search_string] - def _isSection(section, text): + def _isSection(self, section, text): title = '