mirror of
https://github.com/moparisthebest/SickRage
synced 2024-12-13 11:32:20 -05:00
Fixes errors caused by duplicate newznab providers
This commit is contained in:
parent
9914523f64
commit
d6a942698a
@ -67,6 +67,15 @@ def getNewznabProviderList(data):
|
|||||||
defaultList = [makeNewznabProvider(x) for x in getDefaultNewznabProviders().split('!!!')]
|
defaultList = [makeNewznabProvider(x) for x in getDefaultNewznabProviders().split('!!!')]
|
||||||
providerList = filter(lambda x: x, [makeNewznabProvider(x) for x in data.split('!!!')])
|
providerList = filter(lambda x: x, [makeNewznabProvider(x) for x in data.split('!!!')])
|
||||||
|
|
||||||
|
seen_values = set()
|
||||||
|
providerListDeduped = []
|
||||||
|
for d in providerList:
|
||||||
|
value = d.name
|
||||||
|
if value not in seen_values:
|
||||||
|
providerListDeduped.append(d)
|
||||||
|
seen_values.add(value)
|
||||||
|
|
||||||
|
providerList = providerListDeduped
|
||||||
providerDict = dict(zip([x.name for x in providerList], providerList))
|
providerDict = dict(zip([x.name for x in providerList], providerList))
|
||||||
|
|
||||||
for curDefault in defaultList:
|
for curDefault in defaultList:
|
||||||
|
@ -81,15 +81,19 @@ except ImportError:
|
|||||||
|
|
||||||
from sickbeard import browser
|
from sickbeard import browser
|
||||||
|
|
||||||
|
|
||||||
def _handle_reverse_proxy():
|
def _handle_reverse_proxy():
|
||||||
if sickbeard.HANDLE_REVERSE_PROXY:
|
if sickbeard.HANDLE_REVERSE_PROXY:
|
||||||
cherrypy.lib.cptools.proxy()
|
cherrypy.lib.cptools.proxy()
|
||||||
|
|
||||||
|
|
||||||
cherrypy.tools.handle_reverse_proxy = cherrypy.Tool('before_handler', _handle_reverse_proxy)
|
cherrypy.tools.handle_reverse_proxy = cherrypy.Tool('before_handler', _handle_reverse_proxy)
|
||||||
|
|
||||||
|
|
||||||
class PageTemplate(Template):
|
class PageTemplate(Template):
|
||||||
def __init__(self, *args, **KWs):
|
def __init__(self, *args, **KWs):
|
||||||
KWs['file'] = os.path.join(sickbeard.PROG_DIR, "gui/" + sickbeard.GUI_NAME + "/interfaces/default/",KWs['file'])
|
KWs['file'] = os.path.join(sickbeard.PROG_DIR, "gui/" + sickbeard.GUI_NAME + "/interfaces/default/",
|
||||||
|
KWs['file'])
|
||||||
super(PageTemplate, self).__init__(*args, **KWs)
|
super(PageTemplate, self).__init__(*args, **KWs)
|
||||||
self.sbRoot = sickbeard.WEB_ROOT
|
self.sbRoot = sickbeard.WEB_ROOT
|
||||||
self.sbHttpPort = sickbeard.WEB_PORT
|
self.sbHttpPort = sickbeard.WEB_PORT
|
||||||
@ -1629,13 +1633,15 @@ class ConfigProviders:
|
|||||||
|
|
||||||
if hasattr(curTorrentProvider, 'confirmed'):
|
if hasattr(curTorrentProvider, 'confirmed'):
|
||||||
try:
|
try:
|
||||||
curTorrentProvider.confirmed = config.checkbox_to_value(kwargs[curTorrentProvider.getID() + '_confirmed'])
|
curTorrentProvider.confirmed = config.checkbox_to_value(
|
||||||
|
kwargs[curTorrentProvider.getID() + '_confirmed'])
|
||||||
except:
|
except:
|
||||||
curTorrentProvider.confirmed = 0
|
curTorrentProvider.confirmed = 0
|
||||||
|
|
||||||
if hasattr(curTorrentProvider, 'proxy'):
|
if hasattr(curTorrentProvider, 'proxy'):
|
||||||
try:
|
try:
|
||||||
curTorrentProvider.proxy.enabled = config.checkbox_to_value(kwargs[curTorrentProvider.getID() + '_proxy'])
|
curTorrentProvider.proxy.enabled = config.checkbox_to_value(
|
||||||
|
kwargs[curTorrentProvider.getID() + '_proxy'])
|
||||||
except:
|
except:
|
||||||
curTorrentProvider.proxy.enabled = 0
|
curTorrentProvider.proxy.enabled = 0
|
||||||
|
|
||||||
@ -1647,7 +1653,8 @@ class ConfigProviders:
|
|||||||
|
|
||||||
if hasattr(curTorrentProvider, 'freeleech'):
|
if hasattr(curTorrentProvider, 'freeleech'):
|
||||||
try:
|
try:
|
||||||
curTorrentProvider.freeleech = config.checkbox_to_value(kwargs[curTorrentProvider.getID() + '_freeleech'])
|
curTorrentProvider.freeleech = config.checkbox_to_value(
|
||||||
|
kwargs[curTorrentProvider.getID() + '_freeleech'])
|
||||||
except:
|
except:
|
||||||
curTorrentProvider.freeleech = 0
|
curTorrentProvider.freeleech = 0
|
||||||
|
|
||||||
@ -1659,13 +1666,15 @@ class ConfigProviders:
|
|||||||
|
|
||||||
if hasattr(curTorrentProvider, 'search_fallback'):
|
if hasattr(curTorrentProvider, 'search_fallback'):
|
||||||
try:
|
try:
|
||||||
curTorrentProvider.search_fallback = config.checkbox_to_value(kwargs[curTorrentProvider.getID() + '_search_fallback'])
|
curTorrentProvider.search_fallback = config.checkbox_to_value(
|
||||||
|
kwargs[curTorrentProvider.getID() + '_search_fallback'])
|
||||||
except:
|
except:
|
||||||
curTorrentProvider.search_fallback = 0
|
curTorrentProvider.search_fallback = 0
|
||||||
|
|
||||||
if hasattr(curTorrentProvider, 'backlog_only'):
|
if hasattr(curTorrentProvider, 'backlog_only'):
|
||||||
try:
|
try:
|
||||||
curTorrentProvider.backlog_only = config.checkbox_to_value(kwargs[curTorrentProvider.getID() + '_backlog_only'])
|
curTorrentProvider.backlog_only = config.checkbox_to_value(
|
||||||
|
kwargs[curTorrentProvider.getID() + '_backlog_only'])
|
||||||
except:
|
except:
|
||||||
curTorrentProvider.backlog_only = 0
|
curTorrentProvider.backlog_only = 0
|
||||||
|
|
||||||
@ -1728,7 +1737,8 @@ class ConfigNotifications:
|
|||||||
return _munge(t)
|
return _munge(t)
|
||||||
|
|
||||||
@cherrypy.expose
|
@cherrypy.expose
|
||||||
def saveNotifications(self, use_xbmc=None, xbmc_always_on=None, xbmc_notify_onsnatch=None, xbmc_notify_ondownload=None,
|
def saveNotifications(self, use_xbmc=None, xbmc_always_on=None, xbmc_notify_onsnatch=None,
|
||||||
|
xbmc_notify_ondownload=None,
|
||||||
xbmc_notify_onsubtitledownload=None, xbmc_update_onlyfirst=None,
|
xbmc_notify_onsubtitledownload=None, xbmc_update_onlyfirst=None,
|
||||||
xbmc_update_library=None, xbmc_update_full=None, xbmc_host=None, xbmc_username=None,
|
xbmc_update_library=None, xbmc_update_full=None, xbmc_host=None, xbmc_username=None,
|
||||||
xbmc_password=None,
|
xbmc_password=None,
|
||||||
@ -2042,7 +2052,8 @@ class HomePostProcess:
|
|||||||
return _munge(t)
|
return _munge(t)
|
||||||
|
|
||||||
@cherrypy.expose
|
@cherrypy.expose
|
||||||
def processEpisode(self, dir=None, nzbName=None, jobName=None, quiet=None, process_method=None, force=None, is_priority=None, failed="0", type="auto"):
|
def processEpisode(self, dir=None, nzbName=None, jobName=None, quiet=None, process_method=None, force=None,
|
||||||
|
is_priority=None, failed="0", type="auto"):
|
||||||
|
|
||||||
if failed == "0":
|
if failed == "0":
|
||||||
failed = False
|
failed = False
|
||||||
@ -2062,7 +2073,8 @@ class HomePostProcess:
|
|||||||
if not dir:
|
if not dir:
|
||||||
redirect("/home/postprocess/")
|
redirect("/home/postprocess/")
|
||||||
else:
|
else:
|
||||||
result = processTV.processDir(dir, nzbName, process_method=process_method, force=force, is_priority=is_priority, failed=failed, type=type)
|
result = processTV.processDir(dir, nzbName, process_method=process_method, force=force,
|
||||||
|
is_priority=is_priority, failed=failed, type=type)
|
||||||
if quiet is not None and int(quiet) == 1:
|
if quiet is not None and int(quiet) == 1:
|
||||||
return result
|
return result
|
||||||
|
|
||||||
@ -2109,14 +2121,14 @@ class NewHomeAddShows:
|
|||||||
lINDEXER_API_PARMS['custom_ui'] = classes.AllShowsListUI
|
lINDEXER_API_PARMS['custom_ui'] = classes.AllShowsListUI
|
||||||
t = sickbeard.indexerApi(indexer).indexer(**lINDEXER_API_PARMS)
|
t = sickbeard.indexerApi(indexer).indexer(**lINDEXER_API_PARMS)
|
||||||
|
|
||||||
logger.log("Searching for Show with searchterm: %s on Indexer: %s" % (search_term, sickbeard.indexerApi(indexer).name), logger.DEBUG)
|
logger.log("Searching for Show with searchterm: %s on Indexer: %s" % (
|
||||||
|
search_term, sickbeard.indexerApi(indexer).name), logger.DEBUG)
|
||||||
try:
|
try:
|
||||||
# add search results
|
# add search results
|
||||||
results.setdefault(indexer, []).extend(t[search_term])
|
results.setdefault(indexer, []).extend(t[search_term])
|
||||||
except Exception, e:
|
except Exception, e:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
|
|
||||||
map(final_results.extend,
|
map(final_results.extend,
|
||||||
([[sickbeard.indexerApi(id).name, id, sickbeard.indexerApi(id).config["show_url"], int(show['id']),
|
([[sickbeard.indexerApi(id).name, id, sickbeard.indexerApi(id).config["show_url"], int(show['id']),
|
||||||
show['seriesname'], show['firstaired']] for show in shows] for id, shows in
|
show['seriesname'], show['firstaired']] for show in shows] for id, shows in
|
||||||
@ -2301,7 +2313,8 @@ class NewHomeAddShows:
|
|||||||
series_pieces = whichSeries.split('|')
|
series_pieces = whichSeries.split('|')
|
||||||
if (whichSeries and rootDir) or (whichSeries and fullShowPath and len(series_pieces) > 1):
|
if (whichSeries and rootDir) or (whichSeries and fullShowPath and len(series_pieces) > 1):
|
||||||
if len(series_pieces) < 6:
|
if len(series_pieces) < 6:
|
||||||
logger.log("Unable to add show due to show selection. Not anough arguments: %s" % (repr(series_pieces)), logger.ERROR)
|
logger.log("Unable to add show due to show selection. Not anough arguments: %s" % (repr(series_pieces)),
|
||||||
|
logger.ERROR)
|
||||||
ui.notifications.error("Unknown error. Unable to add show due to problem with show selection.")
|
ui.notifications.error("Unknown error. Unable to add show due to problem with show selection.")
|
||||||
redirect('/home/addShows/existingShows/')
|
redirect('/home/addShows/existingShows/')
|
||||||
indexer = int(series_pieces[1])
|
indexer = int(series_pieces[1])
|
||||||
@ -2982,7 +2995,8 @@ class Home:
|
|||||||
@cherrypy.expose
|
@cherrypy.expose
|
||||||
def editShow(self, show=None, location=None, anyQualities=[], bestQualities=[], exceptions_list=[],
|
def editShow(self, show=None, location=None, anyQualities=[], bestQualities=[], exceptions_list=[],
|
||||||
flatten_folders=None, paused=None, directCall=False, air_by_date=None, sports=None, dvdorder=None,
|
flatten_folders=None, paused=None, directCall=False, air_by_date=None, sports=None, dvdorder=None,
|
||||||
indexerLang=None,subtitles=None, archive_firstmatch=None, rls_ignore_words=None, rls_require_words=None):
|
indexerLang=None, subtitles=None, archive_firstmatch=None, rls_ignore_words=None,
|
||||||
|
rls_require_words=None):
|
||||||
|
|
||||||
if show is None:
|
if show is None:
|
||||||
errString = "Invalid show ID: " + str(show)
|
errString = "Invalid show ID: " + str(show)
|
||||||
@ -3569,6 +3583,7 @@ class Home:
|
|||||||
|
|
||||||
return json.dumps({'result': 'failure'})
|
return json.dumps({'result': 'failure'})
|
||||||
|
|
||||||
|
|
||||||
class UI:
|
class UI:
|
||||||
@cherrypy.expose
|
@cherrypy.expose
|
||||||
def add_message(self):
|
def add_message(self):
|
||||||
@ -3811,13 +3826,16 @@ class WebInterface:
|
|||||||
|
|
||||||
for episode in episode_list:
|
for episode in episode_list:
|
||||||
|
|
||||||
air_date_time = network_timezones.parse_date_time(episode['airdate'], show["airs"], show['network']).astimezone(utc)
|
air_date_time = network_timezones.parse_date_time(episode['airdate'], show["airs"],
|
||||||
|
show['network']).astimezone(utc)
|
||||||
air_date_time_end = air_date_time + datetime.timedelta(minutes=helpers.tryInt(show["runtime"], 60))
|
air_date_time_end = air_date_time + datetime.timedelta(minutes=helpers.tryInt(show["runtime"], 60))
|
||||||
|
|
||||||
# Create event for episode
|
# Create event for episode
|
||||||
ical = ical + 'BEGIN:VEVENT\r\n'
|
ical = ical + 'BEGIN:VEVENT\r\n'
|
||||||
ical = ical + 'DTSTART:' + air_date_time.strftime("%Y%m%d") + 'T' + air_date_time.strftime("%H%M%S") + 'Z\r\n'
|
ical = ical + 'DTSTART:' + air_date_time.strftime("%Y%m%d") + 'T' + air_date_time.strftime(
|
||||||
ical = ical + 'DTEND:' + air_date_time_end.strftime("%Y%m%d") + 'T' + air_date_time_end.strftime("%H%M%S") + 'Z\r\n'
|
"%H%M%S") + 'Z\r\n'
|
||||||
|
ical = ical + 'DTEND:' + air_date_time_end.strftime("%Y%m%d") + 'T' + air_date_time_end.strftime(
|
||||||
|
"%H%M%S") + 'Z\r\n'
|
||||||
ical = ical + 'SUMMARY:' + show['show_name'] + ': ' + episode['name'] + '\r\n'
|
ical = ical + 'SUMMARY:' + show['show_name'] + ': ' + episode['name'] + '\r\n'
|
||||||
ical = ical + 'UID:Sick-Beard-' + str(datetime.date.today().isoformat()) + '-' + show[
|
ical = ical + 'UID:Sick-Beard-' + str(datetime.date.today().isoformat()) + '-' + show[
|
||||||
'show_name'].replace(" ", "-") + '-E' + str(episode['episode']) + 'S' + str(
|
'show_name'].replace(" ", "-") + '-E' + str(episode['episode']) + 'S' + str(
|
||||||
|
Loading…
Reference in New Issue
Block a user