1
0
mirror of https://github.com/moparisthebest/SickRage synced 2024-12-12 11:02:21 -05:00

Fixed issue #1055, adding existing shows with prompt for settings

This commit is contained in:
echel0n 2014-12-12 18:49:52 -08:00
parent d183debc4b
commit de24e52be6
3 changed files with 96 additions and 93 deletions

View File

@ -44,11 +44,11 @@
<input type="hidden" id="indexer_timeout" value="$sickbeard.INDEXER_TIMEOUT" /> <input type="hidden" id="indexer_timeout" value="$sickbeard.INDEXER_TIMEOUT" />
#if $use_provided_info: #if $use_provided_info:
Show retrieved from existing metadata: <a href="<%= anon_url(sickbeard.indexerApi(provided_indexer).config['show_url'], provided_indexer_id) %>">$provided_indexer_name</a> Show retrieved from existing metadata: <a href="$anon_url($sickbeard.indexerApi($provided_indexer).config['show_url'], $provided_indexer_id)">$provided_indexer_name</a>
<input type="hidden" name="indexerLang" value="en" /> <input type="hidden" id="indexerLang" name="indexerLang" value="en" />
<input type="hidden" name="whichSeries" value="$provided_indexer_id" /> <input type="hidden" id="whichSeries" name="whichSeries" value="$provided_indexer_id" />
<input type="hidden" id="providedIndexer" name="providedIndexer" value="$provided_indexer" />
<input type="hidden" id="providedName" value="$provided_indexer_name" /> <input type="hidden" id="providedName" value="$provided_indexer_name" />
<input type="hidden" id="providedIndexer" value="$provided_indexer" />
#else: #else:
<input type="text" id="nameToSearch" value="$default_show_name" class="form-control form-control-inline input-sm input350" /> <input type="text" id="nameToSearch" value="$default_show_name" class="form-control form-control-inline input-sm input350" />

View File

@ -1,49 +1,50 @@
$(document).ready(function() { $(document).ready(function() {
$('#checkAll').live('click', function(){ $('#tableDiv').on('click', '#checkAll', function() {
var seasCheck = this; var seasCheck = this;
$('.dirCheck').each(function() {
$('.dirCheck').each(function(){ this.checked = seasCheck.checked;
this.checked = seasCheck.checked;
}); });
}); });
$('#submitShowDirs').click(function(){ $('#submitShowDirs').click(function() {
var dirArr = new Array(); var dirArr = new Array();
$('.dirCheck').each(function(i,w) { $('.dirCheck').each(function(i,w) {
if (this.checked == true) { if (this.checked == true) {
var show = $(this).attr('id'); var show = $(this).attr('id');
var indexer = $(this).closest('tr').find('select').val(); var indexer = $(this).closest('tr').find('select').val();
dirArr.push(encodeURIComponent(indexer + '|' + show)); dirArr.push(encodeURIComponent(indexer + '|' + show));
} }
}); });
if (dirArr.length == 0) if (dirArr.length == 0) {
return false; return false;
}
url = sbRoot+'/home/addShows/addExistingShows?promptForSettings='+ ($('#promptForSettings').prop('checked') ? 'on' : 'off'); url = sbRoot + '/home/addShows/addExistingShows?promptForSettings=' + ($('#promptForSettings').prop('checked') ? 'on' : 'off');
url += '&shows_to_add=' + dirArr.join('&shows_to_add=');
url += '&shows_to_add='+dirArr.join('&shows_to_add=');
window.location.href = url; window.location.href = url;
}); });
function loadContent() { function loadContent() {
var url = ''; var url = '';
$('.dir_check').each(function(i,w){ $('.dir_check').each(function(i,w) {
if ($(w).is(':checked')) { if ($(w).is(':checked')) {
if (url.length) if (url.length) {
url += '&'; url += '&';
}
url += 'rootDir=' + encodeURIComponent($(w).attr('id')); url += 'rootDir=' + encodeURIComponent($(w).attr('id'));
} }
}); });
$('#tableDiv').html('<img id="searchingAnim" src="' + sbRoot + '/images/loading32' + themeSpinner + '.gif" height="32" width="32" /> loading folders...'); $('#tableDiv').html('<img id="searchingAnim" src="' + sbRoot + '/images/loading32.gif" height="32" width="32" /> loading folders...');
$.get(sbRoot+'/home/addShows/massAddTable', url, function(data) { $.get(sbRoot + '/home/addShows/massAddTable/', url, function(data) {
$('#tableDiv').html(data); $('#tableDiv').html(data);
$("#addRootDirTable").tablesorter({ $("#addRootDirTable").tablesorter({
//sortList: [[1,0]], //sortList: [[1,0]],
@ -58,21 +59,24 @@ $(document).ready(function() {
var last_txt = ''; var last_txt = '';
$('#rootDirText').change(function() { $('#rootDirText').change(function() {
if (last_txt == $('#rootDirText').val()) if (last_txt == $('#rootDirText').val()) {
return false; return false;
else } else {
last_txt = $('#rootDirText').val(); last_txt = $('#rootDirText').val();
}
$('#rootDirStaticList').html(''); $('#rootDirStaticList').html('');
$('#rootDirs option').each(function(i, w) { $('#rootDirs option').each(function(i, w) {
$('#rootDirStaticList').append('<li class="ui-state-default ui-corner-all"><input type="checkbox" class="dir_check" id="'+$(w).val()+'" checked=checked> <label for="'+$(w).val()+'" style="color:#09A2FF;"><b>'+$(w).val()+'</b></label></li>') $('#rootDirStaticList').append('<li class="ui-state-default ui-corner-all"><input type="checkbox" class="cb dir_check" id="' + $(w).val() + '" checked=checked> <label for="' + $(w).val() + '"><b>' + $(w).val() + '</b></label></li>');
}); });
loadContent(); loadContent();
}); });
$('.dir_check').live('click', loadContent); $('#rootDirStaticList').on('click', '.dir_check', loadContent);
$('.showManage').live('click', function() { $('#tableDiv').on('click', '.showManage', function(event) {
$( "#tabs" ).tabs( 'select', 0 ); event.preventDefault();
$("#tabs").tabs('option', 'active', 0);
$('html,body').animate({scrollTop:0}, 1000);
}); });
}); });

View File

@ -138,7 +138,7 @@ class BaseHandler(RequestHandler):
url = self.request.uri[len(index_url):] url = self.request.uri[len(index_url):]
if url[:3] != 'api': if url[:3] != 'api':
self.redirect(url) return self.redirect(url)
else: else:
self.write('Wrong API key used') self.write('Wrong API key used')
self.finish() self.finish()
@ -165,7 +165,7 @@ class BaseHandler(RequestHandler):
trace_info, request_info)) trace_info, request_info))
def redirect(self, url, permanent=True, status=None): def redirect(self, url, permanent=True, status=None):
return super(BaseHandler, self).redirect(sickbeard.WEB_ROOT + url, permanent, status) super(BaseHandler, self).redirect(sickbeard.WEB_ROOT + url, permanent, status)
def get_current_user(self, *args, **kwargs): def get_current_user(self, *args, **kwargs):
if not isinstance(self, UI) and sickbeard.WEB_USERNAME and sickbeard.WEB_PASSWORD: if not isinstance(self, UI) and sickbeard.WEB_USERNAME and sickbeard.WEB_PASSWORD:
@ -206,6 +206,7 @@ class WebHandler(BaseHandler):
return result return result
except: except:
logger.log('Failed doing webui callback: %s' % (traceback.format_exc()), logger.ERROR) logger.log('Failed doing webui callback: %s' % (traceback.format_exc()), logger.ERROR)
raise
def async_done(self, results): def async_done(self, results):
try: try:
@ -219,7 +220,7 @@ class WebHandler(BaseHandler):
self.finish() self.finish()
except: except:
logger.log('Failed sending webui reponse: %s' % (traceback.format_exc()), logger.DEBUG) logger.log('Failed sending webui reponse: %s' % (traceback.format_exc()), logger.DEBUG)
self.finish() raise
def _genericMessage(self, subject, message): def _genericMessage(self, subject, message):
t = PageTemplate(rh=self, file="genericMessage.tmpl") t = PageTemplate(rh=self, file="genericMessage.tmpl")
@ -270,7 +271,7 @@ class LoginHandler(BaseHandler):
def get(self, *args, **kwargs): def get(self, *args, **kwargs):
if self.get_current_user(): if self.get_current_user():
self.redirect('/home/') return self.redirect('/home/')
else: else:
t = PageTemplate(rh=self, file="login.tmpl") t = PageTemplate(rh=self, file="login.tmpl")
self.write(ek.ss(t).encode('utf-8', 'xmlcharrefreplace')) self.write(ek.ss(t).encode('utf-8', 'xmlcharrefreplace'))
@ -290,13 +291,13 @@ class LoginHandler(BaseHandler):
remember_me = int(self.get_argument('remember_me', default=0) or 0) remember_me = int(self.get_argument('remember_me', default=0) or 0)
self.set_secure_cookie('user', api_key, expires_days=30 if remember_me > 0 else None) self.set_secure_cookie('user', api_key, expires_days=30 if remember_me > 0 else None)
self.redirect('/home/') return self.redirect('/home/')
class LogoutHandler(BaseHandler): class LogoutHandler(BaseHandler):
def get(self, *args, **kwargs): def get(self, *args, **kwargs):
self.clear_cookie("user") self.clear_cookie("user")
self.redirect('/login/') return self.redirect('/login/')
class KeyHandler(RequestHandler): class KeyHandler(RequestHandler):
@ -323,7 +324,7 @@ class KeyHandler(RequestHandler):
@route('(.*)(/?)') @route('(.*)(/?)')
class WebRoot(WebHandler): class WebRoot(WebHandler):
def index(self): def index(self):
self.redirect('/home/') return self.redirect('/home/')
def robots_txt(self): def robots_txt(self):
""" Keep web crawlers out """ """ Keep web crawlers out """
@ -388,7 +389,7 @@ class WebRoot(WebHandler):
image_path = image_file_name image_path = image_file_name
static_image_path = '/cache' + image_path.replace(sickbeard.CACHE_DIR, '') static_image_path = '/cache' + image_path.replace(sickbeard.CACHE_DIR, '')
self.redirect(static_image_path) return self.redirect(static_image_path)
def setHomeLayout(self, layout): def setHomeLayout(self, layout):
@ -397,7 +398,7 @@ class WebRoot(WebHandler):
sickbeard.HOME_LAYOUT = layout sickbeard.HOME_LAYOUT = layout
self.redirect("/home/") return self.redirect("/home/")
def setPosterSortBy(self, sort): def setPosterSortBy(self, sort):
@ -419,13 +420,13 @@ class WebRoot(WebHandler):
sickbeard.HISTORY_LAYOUT = layout sickbeard.HISTORY_LAYOUT = layout
self.redirect("/history/") return self.redirect("/history/")
def toggleDisplayShowSpecials(self, show): def toggleDisplayShowSpecials(self, show):
sickbeard.DISPLAY_SHOW_SPECIALS = not sickbeard.DISPLAY_SHOW_SPECIALS sickbeard.DISPLAY_SHOW_SPECIALS = not sickbeard.DISPLAY_SHOW_SPECIALS
self.redirect("/home/displayShow?show=" + show) return self.redirect("/home/displayShow?show=" + show)
def setComingEpsLayout(self, layout): def setComingEpsLayout(self, layout):
if layout not in ('poster', 'banner', 'list', 'calendar'): if layout not in ('poster', 'banner', 'list', 'calendar'):
@ -436,13 +437,13 @@ class WebRoot(WebHandler):
sickbeard.COMING_EPS_LAYOUT = layout sickbeard.COMING_EPS_LAYOUT = layout
self.redirect("/comingEpisodes/") return self.redirect("/comingEpisodes/")
def toggleComingEpsDisplayPaused(self): def toggleComingEpsDisplayPaused(self):
sickbeard.COMING_EPS_DISPLAY_PAUSED = not sickbeard.COMING_EPS_DISPLAY_PAUSED sickbeard.COMING_EPS_DISPLAY_PAUSED = not sickbeard.COMING_EPS_DISPLAY_PAUSED
self.redirect("/comingEpisodes/") return self.redirect("/comingEpisodes/")
def setComingEpsSort(self, sort): def setComingEpsSort(self, sort):
if sort not in ('date', 'network', 'show'): if sort not in ('date', 'network', 'show'):
@ -454,7 +455,7 @@ class WebRoot(WebHandler):
sickbeard.COMING_EPS_SORT = sort sickbeard.COMING_EPS_SORT = sort
self.redirect("/comingEpisodes/") return self.redirect("/comingEpisodes/")
def comingEpisodes(self, layout="None"): def comingEpisodes(self, layout="None"):
@ -957,8 +958,7 @@ class Home(WebRoot):
def shutdown(self, pid=None): def shutdown(self, pid=None):
if str(pid) != str(sickbeard.PID): if str(pid) != str(sickbeard.PID):
self.redirect("/home/") return self.redirect("/home/")
return
sickbeard.events.put(sickbeard.events.SystemEvent.SHUTDOWN) sickbeard.events.put(sickbeard.events.SystemEvent.SHUTDOWN)
@ -969,8 +969,7 @@ class Home(WebRoot):
def restart(self, pid=None): def restart(self, pid=None):
if str(pid) != str(sickbeard.PID): if str(pid) != str(sickbeard.PID):
self.redirect("/home/") return self.redirect("/home/")
return
t = PageTemplate(rh=self, file="restart.tmpl") t = PageTemplate(rh=self, file="restart.tmpl")
t.submenu = self.HomeMenu() t.submenu = self.HomeMenu()
@ -982,16 +981,16 @@ class Home(WebRoot):
def updateCheck(self, pid=None): def updateCheck(self, pid=None):
if str(pid) != str(sickbeard.PID): if str(pid) != str(sickbeard.PID):
self.redirect('/home/') return self.redirect('/home/')
self.set_header('Cache-Control', 'max-age=0,no-cache,no-store') self.set_header('Cache-Control', 'max-age=0,no-cache,no-store')
sickbeard.versionCheckScheduler.action.check_for_new_version(force=True) sickbeard.versionCheckScheduler.action.check_for_new_version(force=True)
self.redirect('/home/') return self.redirect('/home/')
def update(self, pid=None): def update(self, pid=None):
if str(pid) != str(sickbeard.PID): if str(pid) != str(sickbeard.PID):
self.redirect('/home/') return self.redirect('/home/')
if sickbeard.versionCheckScheduler.action.update(): if sickbeard.versionCheckScheduler.action.update():
# do a hard restart # do a hard restart
@ -1388,7 +1387,7 @@ class Home(WebRoot):
ui.notifications.error('%d error%s while saving changes:' % (len(errors), "" if len(errors) == 1 else "s"), ui.notifications.error('%d error%s while saving changes:' % (len(errors), "" if len(errors) == 1 else "s"),
'<ul>' + '\n'.join(['<li>%s</li>' % error for error in errors]) + "</ul>") '<ul>' + '\n'.join(['<li>%s</li>' % error for error in errors]) + "</ul>")
self.redirect("/home/displayShow?show=" + show) return self.redirect("/home/displayShow?show=" + show)
def deleteShow(self, show=None, full=0): def deleteShow(self, show=None, full=0):
@ -1415,7 +1414,7 @@ class Home(WebRoot):
(showObj.name, (showObj.name,
('deleted', 'trashed')[sickbeard.TRASH_REMOVE_SHOW], ('deleted', 'trashed')[sickbeard.TRASH_REMOVE_SHOW],
('(media untouched)', '(with all related media)')[bool(full)])) ('(media untouched)', '(with all related media)')[bool(full)]))
self.redirect("/home/") return self.redirect("/home/")
def refreshShow(self, show=None): def refreshShow(self, show=None):
@ -1437,7 +1436,7 @@ class Home(WebRoot):
time.sleep(cpu_presets[sickbeard.CPU_PRESET]) time.sleep(cpu_presets[sickbeard.CPU_PRESET])
self.redirect("/home/displayShow?show=" + str(showObj.indexerid)) return self.redirect("/home/displayShow?show=" + str(showObj.indexerid))
def updateShow(self, show=None, force=0): def updateShow(self, show=None, force=0):
@ -1459,7 +1458,7 @@ class Home(WebRoot):
# just give it some time # just give it some time
time.sleep(cpu_presets[sickbeard.CPU_PRESET]) time.sleep(cpu_presets[sickbeard.CPU_PRESET])
self.redirect("/home/displayShow?show=" + str(showObj.indexerid)) return self.redirect("/home/displayShow?show=" + str(showObj.indexerid))
def subtitleShow(self, show=None, force=0): def subtitleShow(self, show=None, force=0):
@ -1476,7 +1475,7 @@ class Home(WebRoot):
time.sleep(cpu_presets[sickbeard.CPU_PRESET]) time.sleep(cpu_presets[sickbeard.CPU_PRESET])
self.redirect("/home/displayShow?show=" + str(showObj.indexerid)) return self.redirect("/home/displayShow?show=" + str(showObj.indexerid))
def updateKODI(self, showName=None): def updateKODI(self, showName=None):
@ -1492,7 +1491,7 @@ class Home(WebRoot):
ui.notifications.message("Library update command sent to KODI host(s): " + host) ui.notifications.message("Library update command sent to KODI host(s): " + host)
else: else:
ui.notifications.error("Unable to contact one or more KODI host(s): " + host) ui.notifications.error("Unable to contact one or more KODI host(s): " + host)
self.redirect('/home/') return self.redirect('/home/')
def updatePLEX(self): def updatePLEX(self):
@ -1501,7 +1500,7 @@ class Home(WebRoot):
"Library update command sent to Plex Media Server host: " + sickbeard.PLEX_SERVER_HOST) "Library update command sent to Plex Media Server host: " + sickbeard.PLEX_SERVER_HOST)
else: else:
ui.notifications.error("Unable to contact Plex Media Server host: " + sickbeard.PLEX_SERVER_HOST) ui.notifications.error("Unable to contact Plex Media Server host: " + sickbeard.PLEX_SERVER_HOST)
self.redirect('/home/') return self.redirect('/home/')
def setStatus(self, show=None, eps=None, status=None, direct=False): def setStatus(self, show=None, eps=None, status=None, direct=False):
@ -1621,7 +1620,7 @@ class Home(WebRoot):
if direct: if direct:
return json.dumps({'result': 'success'}) return json.dumps({'result': 'success'})
else: else:
self.redirect("/home/displayShow?show=" + show) return self.redirect("/home/displayShow?show=" + show)
def testRename(self, show=None): def testRename(self, show=None):
@ -1688,7 +1687,7 @@ class Home(WebRoot):
return self._genericMessage("Error", "Can't rename episodes when the show dir is missing.") return self._genericMessage("Error", "Can't rename episodes when the show dir is missing.")
if eps is None: if eps is None:
self.redirect("/home/displayShow?show=" + show) return self.redirect("/home/displayShow?show=" + show)
myDB = db.DBConnection() myDB = db.DBConnection()
for curEp in eps.split('|'): for curEp in eps.split('|'):
@ -1715,7 +1714,7 @@ class Home(WebRoot):
root_ep_obj.rename() root_ep_obj.rename()
self.redirect("/home/displayShow?show=" + show) return self.redirect("/home/displayShow?show=" + show)
def searchEpisode(self, show=None, season=None, episode=None): def searchEpisode(self, show=None, season=None, episode=None):
@ -1963,7 +1962,7 @@ class HomePostProcess(Home):
is_priority = False is_priority = False
if not dir: if not dir:
self.redirect("/home/postprocess/") return self.redirect("/home/postprocess/")
else: else:
result = processTV.processDir(dir, nzbName, process_method=process_method, force=force, result = processTV.processDir(dir, nzbName, process_method=process_method, force=force,
is_priority=is_priority, failed=failed, type=type) is_priority=is_priority, failed=failed, type=type)
@ -2286,7 +2285,7 @@ class HomeAddShows(Home):
return "No root directories setup, please go back and add one." return "No root directories setup, please go back and add one."
# done adding show # done adding show
self.redirect('/home/') return self.redirect('/home/')
def addNewShow(self, whichSeries=None, indexerLang="en", rootDir=None, defaultStatus=None, def addNewShow(self, whichSeries=None, indexerLang="en", rootDir=None, defaultStatus=None,
anyQualities=None, bestQualities=None, flatten_folders=None, subtitles=None, anyQualities=None, bestQualities=None, flatten_folders=None, subtitles=None,
@ -2306,7 +2305,7 @@ class HomeAddShows(Home):
def finishAddShow(): def finishAddShow():
# if there are no extra shows then go home # if there are no extra shows then go home
if not other_shows: if not other_shows:
self.redirect('/home/') return self.redirect('/home/')
# peel off the next one # peel off the next one
next_show_dir = other_shows[0] next_show_dir = other_shows[0]
@ -2331,7 +2330,7 @@ class HomeAddShows(Home):
logger.log("Unable to add show due to show selection. Not anough arguments: %s" % (repr(series_pieces)), logger.log("Unable to add show due to show selection. Not anough arguments: %s" % (repr(series_pieces)),
logger.ERROR) 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.")
self.redirect('/home/addShows/existingShows/') return self.redirect('/home/addShows/existingShows/')
indexer = int(series_pieces[1]) indexer = int(series_pieces[1])
indexer_id = int(series_pieces[3]) indexer_id = int(series_pieces[3])
@ -2354,7 +2353,7 @@ class HomeAddShows(Home):
# blanket policy - if the dir exists you should have used "add existing show" numbnuts # blanket policy - if the dir exists you should have used "add existing show" numbnuts
if ek.ek(os.path.isdir, show_dir) and not fullShowPath: if ek.ek(os.path.isdir, show_dir) and not fullShowPath:
ui.notifications.error("Unable to add show", "Folder " + show_dir + " exists already") ui.notifications.error("Unable to add show", "Folder " + show_dir + " exists already")
self.redirect('/home/addShows/existingShows/') return self.redirect('/home/addShows/existingShows/')
# don't create show dir if config says not to # don't create show dir if config says not to
if sickbeard.ADD_SHOWS_WO_DIR: if sickbeard.ADD_SHOWS_WO_DIR:
@ -2365,7 +2364,7 @@ class HomeAddShows(Home):
logger.log(u"Unable to create the folder " + show_dir + ", can't add the show", logger.ERROR) logger.log(u"Unable to create the folder " + show_dir + ", can't add the show", logger.ERROR)
ui.notifications.error("Unable to add show", ui.notifications.error("Unable to add show",
"Unable to create the folder " + show_dir + ", can't add the show") "Unable to create the folder " + show_dir + ", can't add the show")
self.redirect("/home/") return self.redirect("/home/")
else: else:
helpers.chmodAsParent(show_dir) helpers.chmodAsParent(show_dir)
@ -2470,7 +2469,7 @@ class HomeAddShows(Home):
# if we're done then go home # if we're done then go home
if not dirs_only: if not dirs_only:
self.redirect('/home/') return self.redirect('/home/')
# for the remaining shows we need to prompt for each one, so forward this on to the newShow page # for the remaining shows we need to prompt for each one, so forward this on to the newShow page
return self.newShow(dirs_only[0], dirs_only[1:]) return self.newShow(dirs_only[0], dirs_only[1:])
@ -2606,7 +2605,7 @@ class Manage(WebRoot):
WebRoot.Home.setStatus(cur_indexer_id, '|'.join(to_change[cur_indexer_id]), WebRoot.Home.setStatus(cur_indexer_id, '|'.join(to_change[cur_indexer_id]),
newStatus, direct=True) newStatus, direct=True)
self.redirect('/manage/episodeStatuses/') return self.redirect('/manage/episodeStatuses/')
def showSubtitleMissed(self, indexer_id, whichSubs): def showSubtitleMissed(self, indexer_id, whichSubs):
@ -2714,7 +2713,7 @@ class Manage(WebRoot):
show = sickbeard.helpers.findCertainShow(sickbeard.showList, int(cur_indexer_id)) show = sickbeard.helpers.findCertainShow(sickbeard.showList, int(cur_indexer_id))
subtitles = show.getEpisode(int(season), int(episode)).downloadSubtitles() subtitles = show.getEpisode(int(season), int(episode)).downloadSubtitles()
self.redirect('/manage/subtitleMissed/') return self.redirect('/manage/subtitleMissed/')
def backlogShow(self, indexer_id): def backlogShow(self, indexer_id):
@ -2724,7 +2723,7 @@ class Manage(WebRoot):
if show_obj: if show_obj:
sickbeard.backlogSearchScheduler.action.searchBacklog([show_obj]) # @UndefinedVariable sickbeard.backlogSearchScheduler.action.searchBacklog([show_obj]) # @UndefinedVariable
self.redirect("/manage/backlogOverview/") return self.redirect("/manage/backlogOverview/")
def backlogOverview(self): def backlogOverview(self):
@ -2775,7 +2774,7 @@ class Manage(WebRoot):
t.submenu = self.ManageMenu() t.submenu = self.ManageMenu()
if not toEdit: if not toEdit:
self.redirect("/manage/") return self.redirect("/manage/")
showIDs = toEdit.split("|") showIDs = toEdit.split("|")
showList = [] showList = []
@ -2996,7 +2995,7 @@ class Manage(WebRoot):
ui.notifications.error('%d error%s while saving changes:' % (len(errors), "" if len(errors) == 1 else "s"), ui.notifications.error('%d error%s while saving changes:' % (len(errors), "" if len(errors) == 1 else "s"),
" ".join(errors)) " ".join(errors))
self.redirect("/manage/") return self.redirect("/manage/")
def massUpdate(self, toUpdate=None, toRefresh=None, toRename=None, toDelete=None, toRemove=None, toMetadata=None, def massUpdate(self, toUpdate=None, toRefresh=None, toRename=None, toDelete=None, toRemove=None, toMetadata=None,
@ -3116,7 +3115,7 @@ class Manage(WebRoot):
ui.notifications.message("The following actions were queued:", ui.notifications.message("The following actions were queued:",
messageDetail) messageDetail)
self.redirect("/manage/") return self.redirect("/manage/")
def manageTorrents(self): def manageTorrents(self):
@ -3160,7 +3159,7 @@ class Manage(WebRoot):
myDB.action('DELETE FROM failed WHERE release = ?', [release]) myDB.action('DELETE FROM failed WHERE release = ?', [release])
if toRemove: if toRemove:
self.redirect('/manage/failedDownloads/') return self.redirect('/manage/failedDownloads/')
t = PageTemplate(rh=self, file="manage_failedDownloads.tmpl") t = PageTemplate(rh=self, file="manage_failedDownloads.tmpl")
t.failedResults = sqlResults t.failedResults = sqlResults
@ -3192,7 +3191,7 @@ class ManageSearches(Manage):
logger.log(u"Backlog search forced") logger.log(u"Backlog search forced")
ui.notifications.message('Backlog search started') ui.notifications.message('Backlog search started')
self.redirect("/manage/manageSearches/") return self.redirect("/manage/manageSearches/")
def forceSearch(self): def forceSearch(self):
@ -3202,7 +3201,7 @@ class ManageSearches(Manage):
logger.log(u"Daily search forced") logger.log(u"Daily search forced")
ui.notifications.message('Daily search started') ui.notifications.message('Daily search started')
self.redirect("/manage/manageSearches/") return self.redirect("/manage/manageSearches/")
def forceFindPropers(self): def forceFindPropers(self):
@ -3213,7 +3212,7 @@ class ManageSearches(Manage):
logger.log(u"Find propers search forced") logger.log(u"Find propers search forced")
ui.notifications.message('Find propers search started') ui.notifications.message('Find propers search started')
self.redirect("/manage/manageSearches/") return self.redirect("/manage/manageSearches/")
def pauseBacklog(self, paused=None): def pauseBacklog(self, paused=None):
@ -3222,7 +3221,7 @@ class ManageSearches(Manage):
else: else:
sickbeard.searchQueueScheduler.action.unpause_backlog() # @UndefinedVariable sickbeard.searchQueueScheduler.action.unpause_backlog() # @UndefinedVariable
self.redirect("/manage/manageSearches/") return self.redirect("/manage/manageSearches/")
@route('/history/(.*)(/?)') @route('/history/(.*)(/?)')
@ -3304,7 +3303,7 @@ class History(WebRoot):
myDB.action("DELETE FROM history WHERE 1=1") myDB.action("DELETE FROM history WHERE 1=1")
ui.notifications.message('History cleared') ui.notifications.message('History cleared')
self.redirect("/history/") return self.redirect("/history/")
def trimHistory(self): def trimHistory(self):
@ -3314,7 +3313,7 @@ class History(WebRoot):
(datetime.datetime.today() - datetime.timedelta(days=30)).strftime(history.dateFormat))) (datetime.datetime.today() - datetime.timedelta(days=30)).strftime(history.dateFormat)))
ui.notifications.message('Removed history entries greater than 30 days old') ui.notifications.message('Removed history entries greater than 30 days old')
self.redirect("/history/") return self.redirect("/history/")
@route('/config/(.*)(/?)') @route('/config/(.*)(/?)')
@ -3472,7 +3471,7 @@ class ConfigGeneral(Config):
else: else:
ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE)) ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE))
self.redirect("/config/general/") return self.redirect("/config/general/")
@route('/config/backuprestore/(.*)(/?)') @route('/config/backuprestore/(.*)(/?)')
@ -3613,7 +3612,7 @@ class ConfigSearch(Config):
else: else:
ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE)) ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE))
self.redirect("/config/search/") return self.redirect("/config/search/")
@route('/config/postProcessing/(.*)(/?)') @route('/config/postProcessing/(.*)(/?)')
@ -3746,7 +3745,7 @@ class ConfigPostProcessing(Config):
else: else:
ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE)) ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE))
self.redirect("/config/postProcessing/") return self.redirect("/config/postProcessing/")
def testNaming(self, pattern=None, multi=None, abd=False, sports=False, anime_type=None): def testNaming(self, pattern=None, multi=None, abd=False, sports=False, anime_type=None):
@ -4252,7 +4251,7 @@ class ConfigProviders(Config):
else: else:
ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE)) ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE))
self.redirect("/config/providers/") return self.redirect("/config/providers/")
@route('/config/notifications/(.*)(/?)') @route('/config/notifications/(.*)(/?)')
@ -4462,7 +4461,7 @@ class ConfigNotifications(Config):
else: else:
ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE)) ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE))
self.redirect("/config/notifications/") return self.redirect("/config/notifications/")
@route('/config/subtitles/(.*)(/?)') @route('/config/subtitles/(.*)(/?)')
@ -4526,7 +4525,7 @@ class ConfigSubtitles(Config):
else: else:
ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE)) ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE))
self.redirect("/config/subtitles/") return self.redirect("/config/subtitles/")
@route('/config/anime/(.*)(/?)') @route('/config/anime/(.*)(/?)')
@ -4559,7 +4558,7 @@ class ConfigAnime(Config):
else: else:
ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE)) ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE))
self.redirect("/config/anime/") return self.redirect("/config/anime/")
@route('/errorlogs/(.*)(/?)') @route('/errorlogs/(.*)(/?)')
@ -4582,7 +4581,7 @@ class ErrorLogs(WebRoot):
def clearerrors(self): def clearerrors(self):
classes.ErrorViewer.clear() classes.ErrorViewer.clear()
self.redirect("/errorlogs/") return self.redirect("/errorlogs/")
def viewlog(self, minLevel=logger.MESSAGE, maxLines=500): def viewlog(self, minLevel=logger.MESSAGE, maxLines=500):