# Author: Nic Wolfe # URL: http://code.google.com/p/sickbeard/ # # 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 re from sickbeard import helpers from sickbeard import name_cache from sickbeard import logger from sickbeard import db def get_scene_exceptions(indexer_id): """ Given a indexer_id, return a list of all the scene exceptions. """ myDB = db.DBConnection("cache.db") exceptions = myDB.select("SELECT show_name FROM scene_exceptions WHERE indexer_id = ?", [indexer_id]) return [cur_exception["show_name"] for cur_exception in exceptions] def get_scene_exception_by_name(show_name): """ Given a show name, return the indexerid of the exception, None if no exception is present. """ myDB = db.DBConnection("cache.db") # try the obvious case first exception_result = myDB.select("SELECT indexer_id FROM scene_exceptions WHERE LOWER(show_name) = ?", [show_name.lower()]) if exception_result: return int(exception_result[0]["indexer_id"]) all_exception_results = myDB.select("SELECT show_name, indexer_id FROM scene_exceptions") for cur_exception in all_exception_results: cur_exception_name = cur_exception["show_name"] cur_indexer_id = int(cur_exception["indexer_id"]) if show_name.lower() in (cur_exception_name.lower(), helpers.sanitizeSceneName(cur_exception_name).lower().replace('.', ' ')): logger.log(u"Scene exception lookup got tvdb id "+str(cur_indexer_id)+u", using that", logger.DEBUG) return cur_indexer_id return None def retrieve_exceptions(): """ Looks up the exceptions on github, parses them into a dict, and inserts them into the scene_exceptions table in cache.db. Also clears the scene name cache. """ exception_dict = {} # exceptions are stored on github pages url = 'http://midgetspy.github.com/sb_tvdb_scene_exceptions/exceptions.txt' logger.log(u"Check scene exceptions update") url_data = helpers.getURL(url) if url_data is None: # When urlData is None, trouble connecting to github logger.log(u"Check scene exceptions update failed. Unable to get URL: " + url, logger.ERROR) return else: # each exception is on one line with the format indexer_id: 'show name 1', 'show name 2', etc for cur_line in url_data.splitlines(): cur_line = cur_line.decode('utf-8') indexer_id, sep, aliases = cur_line.partition(':') #@UnusedVariable if not aliases: continue indexer_id = int(indexer_id) # regex out the list of shows, taking \' into account alias_list = [re.sub(r'\\(.)', r'\1', x) for x in re.findall(r"'(.*?)(?