mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-22 01:23:43 +00:00
Merge pull request #807 from JackDandy/feature/ChangeAddRoots
Change improve reverse proxy web_root support.
This commit is contained in:
commit
2021116657
14 changed files with 215 additions and 220 deletions
|
@ -216,6 +216,7 @@
|
||||||
* Change ensure sbdatetime functions return formatted string instead of tuple
|
* Change ensure sbdatetime functions return formatted string instead of tuple
|
||||||
* Change image cache processing for browse Trakt page
|
* Change image cache processing for browse Trakt page
|
||||||
* Change logging for newznab response code 910 and add check for empty response data
|
* Change logging for newznab response code 910 and add check for empty response data
|
||||||
|
* Change improve reverse proxy web_root support
|
||||||
|
|
||||||
|
|
||||||
### 0.11.16 (2016-10-16 17:30:00 UTC)
|
### 0.11.16 (2016-10-16 17:30:00 UTC)
|
||||||
|
|
|
@ -266,7 +266,7 @@
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<input type="text" name="show_tags" id="show_tags" value="$show_tags" class="form-control input-sm input300">
|
<input type="text" name="show_tags" id="show_tags" value="$show_tags" class="form-control input-sm input300">
|
||||||
<span>comma separated names</span>
|
<span>comma separated names</span>
|
||||||
<p class="clear-left note">group shows to the order of this custom list (add shows to groups with <a href="/manage/">mass edit</a>)</p>
|
<p class="clear-left note">group shows to the order of this custom list (add shows to groups with <a href="$sbRoot/manage/">mass edit</a>)</p>
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -573,14 +573,14 @@
|
||||||
<td class="col-search">
|
<td class="col-search">
|
||||||
#if 0 != int($epResult['season'])
|
#if 0 != int($epResult['season'])
|
||||||
#if (int($epResult['status']) in $Quality.SNATCHED or int($epResult['status']) in $Quality.DOWNLOADED) and $sickbeard.USE_FAILED_DOWNLOADS
|
#if (int($epResult['status']) in $Quality.SNATCHED or int($epResult['status']) in $Quality.DOWNLOADED) and $sickbeard.USE_FAILED_DOWNLOADS
|
||||||
<a class="epRetry" id="#echo $epStr#" name="#echo $epStr#" href="retryEpisode?show=$show.indexerid&season=$epResult['season']&episode=$epResult['episode']"><img src="$sbRoot/images/search16.png" height="16" alt="retry" title="Retry download" /></a>
|
<a class="epRetry" id="#echo $epStr#" name="#echo $epStr#" href="$sbRoot/home/retryEpisode?show=$show.indexerid&season=$epResult['season']&episode=$epResult['episode']"><img src="$sbRoot/images/search16.png" height="16" alt="retry" title="Retry download" /></a>
|
||||||
#else:
|
#else:
|
||||||
<a class="epSearch" id="#echo $epStr#" name="#echo $epStr#" href="searchEpisode?show=$show.indexerid&season=$epResult['season']&episode=$epResult['episode']"><img src="$sbRoot/images/search16.png" width="16" height="16" alt="search" title="Manual search" /></a>
|
<a class="epSearch" id="#echo $epStr#" name="#echo $epStr#" href="$sbRoot/home/searchEpisode?show=$show.indexerid&season=$epResult['season']&episode=$epResult['episode']"><img src="$sbRoot/images/search16.png" width="16" height="16" alt="search" title="Manual search" /></a>
|
||||||
#end if
|
#end if
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#if $sickbeard.USE_SUBTITLES and $show.subtitles and len(set(str($epResult['subtitles']).split(',')).intersection(set($subtitles.wantedLanguages()))) < len($subtitles.wantedLanguages()) and $epResult['location']
|
#if $sickbeard.USE_SUBTITLES and $show.subtitles and len(set(str($epResult['subtitles']).split(',')).intersection(set($subtitles.wantedLanguages()))) < len($subtitles.wantedLanguages()) and $epResult['location']
|
||||||
<a class="epSubtitlesSearch" href="searchEpisodeSubtitles?show=$show.indexerid&season=$epResult['season']&episode=$epResult['episode']"><img src="$sbRoot/images/closed_captioning.png" height="16" alt="search subtitles" title="Search subtitles" /></a>
|
<a class="epSubtitlesSearch" href="$sbRoot/home/searchEpisodeSubtitles?show=$show.indexerid&season=$epResult['season']&episode=$epResult['episode']"><img src="$sbRoot/images/closed_captioning.png" height="16" alt="search subtitles" title="Search subtitles" /></a>
|
||||||
#end if
|
#end if
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
|
@ -282,7 +282,7 @@
|
||||||
#if None is $curLoadingShow.show
|
#if None is $curLoadingShow.show
|
||||||
Loading... ($curLoadingShow.show_name)
|
Loading... ($curLoadingShow.show_name)
|
||||||
#else
|
#else
|
||||||
<a href="displayShow?show=$curLoadingShow.show.indexerid">$curLoadingShow.show.name</a>
|
<a href="$sbRoot/home/displayShow?show=$curLoadingShow.show.indexerid">$curLoadingShow.show.name</a>
|
||||||
#end if
|
#end if
|
||||||
</td>
|
</td>
|
||||||
<td></td>
|
<td></td>
|
||||||
|
|
|
@ -1,16 +1,87 @@
|
||||||
#import sickbeard
|
<!DOCTYPE html>
|
||||||
#import datetime
|
<head>
|
||||||
#from sickbeard.common import *
|
<meta charset="utf-8">
|
||||||
#from sickbeard import db
|
<meta name="robots" content="noindex, nofollow, noarchive, nocache, noodp, noydir, noimageindex, nosnippet">
|
||||||
##
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
#set global $title = 'Home'
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||||
#set global $header = 'Restarting SickGear'
|
|
||||||
#set global $sbPath = '..'
|
|
||||||
#set global $topmenu = 'home'
|
|
||||||
##
|
|
||||||
#import os.path
|
|
||||||
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_top.tmpl')
|
|
||||||
|
|
||||||
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/restart_bare.tmpl')
|
<title>SickGear - Restarting</title>
|
||||||
|
<link rel="shortcut icon" href="$sbRoot/images/ico/favicon.ico">
|
||||||
|
<link rel="apple-touch-icon" sizes="180x180" href="$sbRoot/images/ico/apple-touch-icon-180x180.png">
|
||||||
|
<link rel="apple-touch-icon" sizes="152x152" href="$sbRoot/images/ico/apple-touch-icon-152x152.png">
|
||||||
|
<link rel="apple-touch-icon" sizes="144x144" href="$sbRoot/images/ico/apple-touch-icon-144x144.png">
|
||||||
|
<link rel="apple-touch-icon" sizes="120x120" href="$sbRoot/images/ico/apple-touch-icon-120x120.png">
|
||||||
|
<link rel="apple-touch-icon" sizes="114x114" href="$sbRoot/images/ico/apple-touch-icon-114x114.png">
|
||||||
|
<link rel="apple-touch-icon" sizes="76x76" href="$sbRoot/images/ico/apple-touch-icon-76x76.png">
|
||||||
|
<link rel="apple-touch-icon" sizes="72x72" href="$sbRoot/images/ico/apple-touch-icon-72x72.png">
|
||||||
|
<link rel="apple-touch-icon" sizes="60x60" href="$sbRoot/images/ico/apple-touch-icon-60x60.png">
|
||||||
|
<link rel="apple-touch-icon" sizes="57x57" href="$sbRoot/images/ico/apple-touch-icon-57x57.png">
|
||||||
|
<link rel="icon" type="image/png" href="$sbRoot/images/ico/favicon-192x192.png" sizes="192x192">
|
||||||
|
<link rel="icon" type="image/png" href="$sbRoot/images/ico/favicon-160x160.png" sizes="160x160">
|
||||||
|
<link rel="icon" type="image/png" href="$sbRoot/images/ico/favicon-96x96.png" sizes="96x96">
|
||||||
|
<link rel="icon" type="image/png" href="$sbRoot/images/ico/favicon-32x32.png" sizes="32x32">
|
||||||
|
<link rel="icon" type="image/png" href="$sbRoot/images/ico/favicon-16x16.png" sizes="16x16">
|
||||||
|
<meta name="msapplication-TileColor" content="#2b5797">
|
||||||
|
<meta name="msapplication-TileImage" content="$sbRoot/images/ico/mstile-144x144.png">
|
||||||
|
<meta name="msapplication-config" content="$sbRoot/css/browserconfig.xml">
|
||||||
|
|
||||||
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_bottom.tmpl')
|
<script type="text/javascript" src="$sbRoot/js/lib/jquery-1.8.3.min.js?v=$sbPID"></script>
|
||||||
|
|
||||||
|
#try:
|
||||||
|
#set sgHost = $sbHost
|
||||||
|
#set sgPort = $sbHttpPort
|
||||||
|
#set sgUseHttps = $sbHttpsEnabled
|
||||||
|
#set themeSpinner = $sbThemeName
|
||||||
|
#except NameMapper.NotFound:
|
||||||
|
#set sgHost = 'localhost'
|
||||||
|
#set sgPort = $sickbeard.WEB_PORT
|
||||||
|
#set sgUseHttps = False
|
||||||
|
#set themeSpinner = $sickbeard.THEME_NAME
|
||||||
|
#end try
|
||||||
|
#set themeSpinner = '-dark' if 'dark' == themeSpinner else ''
|
||||||
|
##
|
||||||
|
<script type="text/javascript" charset="utf-8">
|
||||||
|
<!--
|
||||||
|
\$.SickGear = {
|
||||||
|
Root: '$sbRoot',
|
||||||
|
Host: '$sgHost',
|
||||||
|
Port: '$sgPort',
|
||||||
|
UseHttps: #echo ('!1', '!0')[False != $sgUseHttps and 0 != $sgUseHttps]#
|
||||||
|
};
|
||||||
|
//-->
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<script type="text/javascript" src="$sbRoot/js/restart.js?v=$sbPID"></script>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
body{padding-top:0 !important}.sglogo{display:block;width:138px;height:74px;margin-bottom:-10px;background:url(${sbRoot}/images/sickgear.png) no-repeat 0 0}.bfr{position:absolute;left:-999px;top:-999px}.bfr img{width:16px;height:16px}.spinner{display:inline-block;width:16px;height:16px;background:url(${sbRoot}/images/loading16${themeSpinner}.gif) no-repeat 0 0}.sub-title{padding-bottom:10px}.desc, .images i{margin-right:6px}.images i{vertical-align:middle}.hide,.hide-yes,.hide-no{display:none}#restart_fail_message{padding-top:10px}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<link rel="stylesheet" type="text/css" href="$sbRoot/css/style.css?v=$sbPID">
|
||||||
|
<link rel="stylesheet" type="text/css" href="$sbRoot/css/#echo ('dark', 'light')['' == themeSpinner]#.css?v=$sbPID">
|
||||||
|
|
||||||
|
</head><body><span class="sglogo"></span>
|
||||||
|
<div class="bfr"><img src="$sbRoot/images/loading16${themeSpinner}.gif" /><img src="$sbRoot/images/yes16.png" /><img src="$sbRoot/images/no16.png" /></div>
|
||||||
|
|
||||||
|
<h2 class="sub-title">Performing Restart</h2>
|
||||||
|
|
||||||
|
<div id="shut_down_message">
|
||||||
|
<span class="desc"><span class="grey-text">Waiting for SickGear to</span> shut down: </span>
|
||||||
|
<span class="images"><i class="spinner"></i><span class="hide-yes"><i class="yes"></i></span></span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="hide" id="restart_message">
|
||||||
|
<span class="desc"><span class="grey-text">Waiting for SickGear to</span> start up: </span>
|
||||||
|
<span class="images"><i class="spinner"></i><span class="hide-yes"><i class="yes"></i></span><span class="hide-no"><i class="no"></i></span></span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="hide" id="refresh_message">
|
||||||
|
<span class="desc"><span class="grey-text">Waiting for SickGear </span> home page: </span>
|
||||||
|
<span class="images"><i class="spinner"></i></span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="hide" id="restart_fail_message">
|
||||||
|
<span class="red-text">Error:</span> The restart timed out, perhaps something prevented SickGear from starting ?
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</body></html>
|
||||||
|
|
|
@ -1,51 +1,7 @@
|
||||||
<script type="text/javascript" charset="utf-8">
|
##############################################################################################################
|
||||||
<!--
|
## This file is deprecated (Oct 2016) but services systems in transition to the refactored restart template ##
|
||||||
#try:
|
##############################################################################################################
|
||||||
#set curSBHost = $sbHost
|
##
|
||||||
#set curSBHttpPort = $sbHttpPort
|
#import sickbeard
|
||||||
#set curSBHttpsEnabled = $sbHttpsEnabled
|
#import os.path
|
||||||
#set curSBHandleReverseProxy = $sbHandleReverseProxy
|
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/restart.tmpl')
|
||||||
#set themeSpinner = $sbThemeName
|
|
||||||
#except NameMapper.NotFound:
|
|
||||||
#set curSBHost = "localhost"
|
|
||||||
#set curSBHttpPort = $sickbeard.WEB_PORT
|
|
||||||
#set curSBHttpsEnabled = "False"
|
|
||||||
#set curSBHandleReverseProxy = "False"
|
|
||||||
#set themeSpinner = $sickbeard.THEME_NAME
|
|
||||||
#end try
|
|
||||||
sbRoot = "$sbRoot";
|
|
||||||
sbHttpPort = "$curSBHttpPort";
|
|
||||||
sbHttpsEnabled = "$curSBHttpsEnabled";
|
|
||||||
sbHandleReverseProxy = "$curSBHandleReverseProxy";
|
|
||||||
sbHost = "$curSBHost";
|
|
||||||
//-->
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<script type="text/javascript" src="$sbRoot/js/lib/jquery-1.8.3.min.js?v=$sbPID"></script>
|
|
||||||
<script type="text/javascript" src="$sbRoot/js/restart.js?v=$sbPID"></script>
|
|
||||||
|
|
||||||
#set themeSpinner = '-dark' if 'dark' == themeSpinner else ''
|
|
||||||
<h2>Performing Restart</h2>
|
|
||||||
<br />
|
|
||||||
<div id="shut_down_message">
|
|
||||||
Waiting for SickGear to shut down:
|
|
||||||
<img src="$sbRoot/images/loading16${themeSpinner}.gif" height="16" width="16" id="shut_down_loading" />
|
|
||||||
<img src="$sbRoot/images/yes16.png" height="16" width="16" id="shut_down_success" style="display: none;" />
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="restart_message" style="display: none;">
|
|
||||||
Waiting for SickGear to start again:
|
|
||||||
<img src="$sbRoot/images/loading16${themeSpinner}.gif" height="16" width="16" id="restart_loading" />
|
|
||||||
<img src="$sbRoot/images/yes16.png" height="16" width="16" id="restart_success" style="display: none;" />
|
|
||||||
<img src="$sbRoot/images/no16.png" height="16" width="16" id="restart_failure" style="display: none;" />
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="refresh_message" style="display: none;">
|
|
||||||
Loading the home page:
|
|
||||||
<img src="$sbRoot/images/loading16${themeSpinner}.gif" height="16" width="16" id="refresh_loading" />
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="restart_fail_message" style="display: none;">
|
|
||||||
Error: The restart has timed out, perhaps something prevented SickGear from starting again?
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
|
@ -11,9 +11,9 @@
|
||||||
#import os.path
|
#import os.path
|
||||||
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_top.tmpl')
|
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_top.tmpl')
|
||||||
|
|
||||||
#if $varExists('header')
|
#if $varExists('header')
|
||||||
<h1 class="header">$header</h1>
|
<h1 class="header">$header</h1>
|
||||||
#else
|
#else
|
||||||
<h1 class="title">$title</h1>
|
<h1 class="title">$title</h1>
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
|
@ -36,11 +36,11 @@
|
||||||
#set $curSeason = -1
|
#set $curSeason = -1
|
||||||
#set $odd = False
|
#set $odd = False
|
||||||
<div class="clearfix padbottom">
|
<div class="clearfix padbottom">
|
||||||
<button class="btn seriesCheck">Select All Episodes</button>
|
<button class="btn seriesCheck">Select All Episodes</button>
|
||||||
<button class="btn clearAll">Clear All</button>
|
<button class="btn clearAll">Clear All</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<input type="submit" value="Rename Selected" class="btn btn-success"> <a href="/home/displayShow?show=$show.indexerid" class="btn btn-danger">Cancel Rename</a>
|
<input type="submit" value="Rename Selected" class="btn btn-success"> <a href="$sbRoot/home/displayShow?show=$show.indexerid" class="btn btn-danger">Cancel Rename</a>
|
||||||
|
|
||||||
<table id="testRenameTable" class="sickbeardTable" border="0">
|
<table id="testRenameTable" class="sickbeardTable" border="0">
|
||||||
##
|
##
|
||||||
|
@ -92,7 +92,7 @@
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
<div style="clear:both;margin-top:20px">
|
<div style="clear:both;margin-top:20px">
|
||||||
<input type="submit" value="Rename Selected" class="btn btn-success"> <a href="/home/displayShow?show=$show.indexerid" class="btn btn-danger">Cancel Rename</a>
|
<input type="submit" value="Rename Selected" class="btn btn-success"> <a href="$sbRoot/home/displayShow?show=$show.indexerid" class="btn btn-danger">Cancel Rename</a>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_bottom.tmpl')
|
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_bottom.tmpl')
|
||||||
|
|
|
@ -15,7 +15,7 @@ $(document).ready(function() {
|
||||||
subtitles = subtitles.split(',')
|
subtitles = subtitles.split(',')
|
||||||
for (i in subtitles)
|
for (i in subtitles)
|
||||||
{
|
{
|
||||||
row += ' <img src="/images/flags/'+subtitles[i]+'.png" width="16" height="11" alt="'+subtitles[i]+'" /> ';
|
row += ' <img src="' + sbRoot + '/images/flags/'+subtitles[i]+'.png" width="16" height="11" alt="'+subtitles[i]+'" /> ';
|
||||||
}
|
}
|
||||||
row += ' </td>';
|
row += ' </td>';
|
||||||
row += ' </tr>'
|
row += ' </tr>'
|
||||||
|
|
|
@ -14,7 +14,7 @@ $(document).ready(function() {
|
||||||
if (0 == editArr.length)
|
if (0 == editArr.length)
|
||||||
return !1;
|
return !1;
|
||||||
|
|
||||||
window.location.href = $.SickGear.Root + 'massEdit?toEdit=' + editArr.join('|');
|
window.location.href = $.SickGear.Root + '/manage/massEdit?toEdit=' + editArr.join('|');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,79 +1,85 @@
|
||||||
if (sbHttpsEnabled != "False" && sbHttpsEnabled != 0) {
|
/** @namespace $.SickGear.Root */
|
||||||
var sb_base_url = 'https://' + sbHost + ':' + sbHttpPort + sbRoot;
|
/** @namespace $.SickGear.Host */
|
||||||
} else {
|
/** @namespace $.SickGear.Port */
|
||||||
var sb_base_url = 'http://' + sbHost + ':' + sbHttpPort + sbRoot;
|
/** @namespace $.SickGear.UseHttps */
|
||||||
}
|
/** @namespace data.msg */
|
||||||
|
|
||||||
var base_url = window.location.protocol + '//' + window.location.host + sbRoot;
|
var sgRoot = $.SickGear.Root,
|
||||||
var is_alive_url = sbRoot + '/home/is_alive/';
|
browserUrl = window.location.protocol + '//' + window.location.host + sgRoot,
|
||||||
var timeout_id;
|
baseUrl = 'http' + ($.SickGear.UseHttps ? 's' : '') + '://' + $.SickGear.Host + ':'
|
||||||
var current_pid = '';
|
+ (('' == sgRoot) ? $.SickGear.Port : location.port) + sgRoot,
|
||||||
var num_restart_waits = 0;
|
isAliveUrl = sgRoot + '/home/is_alive/',
|
||||||
|
timeoutId;
|
||||||
|
$.SickGear.currentPid = '';
|
||||||
|
$.SickGear.numRestartWaits = 0;
|
||||||
|
|
||||||
function is_alive() {
|
function is_alive() {
|
||||||
timeout_id = 0;
|
timeoutId = 0;
|
||||||
$.get(is_alive_url, function(data) {
|
$.get(isAliveUrl, function(data) {
|
||||||
|
|
||||||
// if it's still initalizing then just wait and try again
|
if ('nope' == data.msg.toString()) {
|
||||||
if (data.msg == 'nope') {
|
// if initialising then just wait and try again
|
||||||
$('#shut_down_loading').hide();
|
|
||||||
$('#shut_down_success').show();
|
|
||||||
$('#restart_message').show();
|
|
||||||
setTimeout('is_alive()', 1000);
|
|
||||||
} else {
|
|
||||||
// if this is before we've even shut down then just try again later
|
|
||||||
if (current_pid == '' || data.msg == current_pid) {
|
|
||||||
current_pid = data.msg;
|
|
||||||
setTimeout(is_alive, 1000);
|
|
||||||
|
|
||||||
// if we're ready to go then redirect to new url
|
$('#shut_down_message').find('.spinner,.hide-yes').removeClass();
|
||||||
} else {
|
$('#restart_message').removeClass();
|
||||||
$('#restart_loading').hide();
|
setTimeout(is_alive, 250);
|
||||||
$('#restart_success').show();
|
|
||||||
$('#refresh_message').show();
|
} else if ('' == $.SickGear.currentPid || $.SickGear.currentPid == data.msg) {
|
||||||
window.location = sb_base_url + '/home/';
|
// if this is before we've even shut down then just try again later
|
||||||
}
|
|
||||||
}
|
$.SickGear.currentPid = data.msg;
|
||||||
}, 'jsonp');
|
setTimeout(is_alive, 250);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
// if we're ready to go then redirect to new url
|
||||||
|
|
||||||
|
$('#restart_message').find('.spinner,.hide-yes').removeClass();
|
||||||
|
$('#refresh_message').removeClass();
|
||||||
|
window.location = baseUrl + '/home/';
|
||||||
|
}
|
||||||
|
}, 'jsonp');
|
||||||
}
|
}
|
||||||
|
|
||||||
$(document).ready(function() {
|
$(document).ready(function() {
|
||||||
|
|
||||||
is_alive();
|
is_alive();
|
||||||
|
|
||||||
$('#shut_down_message').ajaxError(function(e, jqxhr, settings, exception) {
|
//noinspection JSUnusedLocalSymbols
|
||||||
num_restart_waits += 1;
|
$('#shut_down_message').ajaxError(function(e, jqxhr, settings, exception) {
|
||||||
|
$.SickGear.numRestartWaits += 1;
|
||||||
|
|
||||||
$('#shut_down_loading').hide();
|
$('#shut_down_message').find('.spinner,.hide-yes').removeClass();
|
||||||
$('#shut_down_success').show();
|
$('#restart_message').removeClass();
|
||||||
$('#restart_message').show();
|
isAliveUrl = baseUrl + '/home/is_alive/';
|
||||||
is_alive_url = sb_base_url + '/home/is_alive/';
|
|
||||||
|
|
||||||
// if https is enabled or you are currently on https and the port or protocol changed just wait 5 seconds then redirect.
|
// if https is enabled or you are currently on https and the port or protocol changed just wait 5 seconds then redirect.
|
||||||
// This is because the ajax will fail if the cert is untrusted or the the http ajax requst from https will fail because of mixed content error.
|
// This is because the ajax will fail if the cert is untrusted or the the http ajax request from https will fail because of mixed content error.
|
||||||
if ((sbHttpsEnabled != "False" && sbHttpsEnabled != 0) || window.location.protocol == "https:") {
|
if ($.SickGear.UseHttps || 'https:' == window.location.protocol) {
|
||||||
if (base_url != sb_base_url) {
|
if (browserUrl != baseUrl) {
|
||||||
timeout_id = 1;
|
|
||||||
setTimeout(function(){
|
|
||||||
$('#restart_loading').hide();
|
|
||||||
$('#restart_success').show();
|
|
||||||
$('#refresh_message').show();
|
|
||||||
}, 3000);
|
|
||||||
setTimeout("window.location = sb_base_url + '/home/'", 5000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// if it is taking forever just give up
|
timeoutId = 1;
|
||||||
if (num_restart_waits > 90) {
|
setTimeout(function() {
|
||||||
$('#restart_loading').hide();
|
$('#restart_message').find('.spinner,.hide-yes').removeClass();
|
||||||
$('#restart_failure').show();
|
$('#refresh_message').removeClass();
|
||||||
$('#restart_fail_message').show();
|
}, 3000);
|
||||||
return;
|
setTimeout(function() {
|
||||||
}
|
window.location = baseUrl + '/home/'
|
||||||
|
}, 5000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (timeout_id == 0) {
|
// if it is taking forever just give up
|
||||||
timeout_id = setTimeout('is_alive()', 1000);
|
if (90 < $.SickGear.numRestartWaits) {
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
$('#restart_message').find('.spinner,.yes,.hide-no').removeClass();
|
||||||
|
$('#restart_fail_message').removeClass();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (0 == timeoutId) {
|
||||||
|
|
||||||
|
timeoutId = setTimeout(is_alive, 250);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
|
@ -1310,11 +1310,7 @@ def start():
|
||||||
|
|
||||||
|
|
||||||
def halt():
|
def halt():
|
||||||
global __INITIALIZED__, backlogSearchScheduler, \
|
global __INITIALIZED__, started
|
||||||
showUpdateScheduler, versionCheckScheduler, showQueueScheduler, \
|
|
||||||
properFinderScheduler, autoPostProcesserScheduler, searchQueueScheduler, \
|
|
||||||
subtitlesFinderScheduler, traktCheckerScheduler, \
|
|
||||||
recentSearchScheduler, events, started
|
|
||||||
|
|
||||||
with INIT_LOCK:
|
with INIT_LOCK:
|
||||||
|
|
||||||
|
@ -1322,54 +1318,30 @@ def halt():
|
||||||
|
|
||||||
logger.log(u'Aborting all threads')
|
logger.log(u'Aborting all threads')
|
||||||
|
|
||||||
events.stop.set()
|
schedulers = [
|
||||||
logger.log(u'Waiting for the EVENTS thread to exit')
|
recentSearchScheduler,
|
||||||
try:
|
backlogSearchScheduler,
|
||||||
events.join(10)
|
showUpdateScheduler,
|
||||||
except:
|
versionCheckScheduler,
|
||||||
pass
|
showQueueScheduler,
|
||||||
|
searchQueueScheduler,
|
||||||
|
|
||||||
recentSearchScheduler.stop.set()
|
properFinderScheduler,
|
||||||
logger.log(u'Waiting for the RECENTSEARCH thread to exit')
|
autoPostProcesserScheduler,
|
||||||
try:
|
subtitlesFinderScheduler,
|
||||||
recentSearchScheduler.join(10)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
backlogSearchScheduler.stop.set()
|
events
|
||||||
logger.log(u'Waiting for the BACKLOG thread to exit')
|
]
|
||||||
try:
|
|
||||||
backlogSearchScheduler.join(10)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
showUpdateScheduler.stop.set()
|
for thread in schedulers:
|
||||||
logger.log(u'Waiting for the SHOWUPDATER thread to exit')
|
thread.stop.set()
|
||||||
try:
|
|
||||||
showUpdateScheduler.join(10)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
versionCheckScheduler.stop.set()
|
for thread in schedulers:
|
||||||
logger.log(u'Waiting for the VERSIONCHECKER thread to exit')
|
logger.log('Waiting for the %s thread to exit' % thread.name)
|
||||||
try:
|
try:
|
||||||
versionCheckScheduler.join(10)
|
thread.join(10)
|
||||||
except:
|
except RuntimeError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
showQueueScheduler.stop.set()
|
|
||||||
logger.log(u'Waiting for the SHOWQUEUE thread to exit')
|
|
||||||
try:
|
|
||||||
showQueueScheduler.join(10)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
searchQueueScheduler.stop.set()
|
|
||||||
logger.log(u'Waiting for the SEARCHQUEUE thread to exit')
|
|
||||||
try:
|
|
||||||
searchQueueScheduler.join(10)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
if PROCESS_AUTOMATICALLY:
|
if PROCESS_AUTOMATICALLY:
|
||||||
autoPostProcesserScheduler.stop.set()
|
autoPostProcesserScheduler.stop.set()
|
||||||
|
@ -1379,14 +1351,6 @@ def halt():
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
# if USE_TRAKT:
|
|
||||||
# traktCheckerScheduler.stop.set()
|
|
||||||
# logger.log(u'Waiting for the TRAKTCHECKER thread to exit')
|
|
||||||
# try:
|
|
||||||
# traktCheckerScheduler.join(10)
|
|
||||||
# except:
|
|
||||||
# pass
|
|
||||||
|
|
||||||
if DOWNLOAD_PROPERS:
|
if DOWNLOAD_PROPERS:
|
||||||
properFinderScheduler.stop.set()
|
properFinderScheduler.stop.set()
|
||||||
logger.log(u'Waiting for the PROPERFINDER thread to exit')
|
logger.log(u'Waiting for the PROPERFINDER thread to exit')
|
||||||
|
|
|
@ -196,17 +196,18 @@ class PLEXNotifier:
|
||||||
|
|
||||||
if sickbeard.USE_PLEX and sickbeard.PLEX_UPDATE_LIBRARY or test:
|
if sickbeard.USE_PLEX and sickbeard.PLEX_UPDATE_LIBRARY or test:
|
||||||
|
|
||||||
if not sickbeard.PLEX_SERVER_HOST and not any([host]):
|
if not test:
|
||||||
msg = u'No Plex Media Server host specified, check your settings'
|
if not sickbeard.PLEX_SERVER_HOST:
|
||||||
self.log(msg, logger.DEBUG)
|
msg = u'No Plex Media Server host specified, check your settings'
|
||||||
return '%sFail: %s' % (('', '<br />')[test], msg)
|
self.log(msg, logger.DEBUG)
|
||||||
|
return '%sFail: %s' % (('', '<br />')[test], msg)
|
||||||
|
|
||||||
if not host:
|
if not host:
|
||||||
host = sickbeard.PLEX_SERVER_HOST
|
host = sickbeard.PLEX_SERVER_HOST
|
||||||
if not username:
|
if not username:
|
||||||
username = sickbeard.PLEX_USERNAME
|
username = sickbeard.PLEX_USERNAME
|
||||||
if not password:
|
if not password:
|
||||||
password = sickbeard.PLEX_PASSWORD
|
password = sickbeard.PLEX_PASSWORD
|
||||||
|
|
||||||
# if username and password were provided, fetch the auth token from plex.tv
|
# if username and password were provided, fetch the auth token from plex.tv
|
||||||
token_arg = None
|
token_arg = None
|
||||||
|
|
|
@ -707,7 +707,7 @@ class ProcessTVShow(object):
|
||||||
# processed in the past
|
# processed in the past
|
||||||
return False
|
return False
|
||||||
|
|
||||||
showlink = ('for "<a href="/home/displayShow?show=%s" target="_blank">%s</a>"' % (parse_result.show.indexerid, parse_result.show.name),
|
showlink = ('for "<a href="%s/home/displayShow?show=%s" target="_blank">%s</a>"' % (sickbeard.WEB_ROOT, parse_result.show.indexerid, parse_result.show.name),
|
||||||
parse_result.show.name)[self.any_vid_processed]
|
parse_result.show.name)[self.any_vid_processed]
|
||||||
|
|
||||||
ep_detail_sql = ''
|
ep_detail_sql = ''
|
||||||
|
|
|
@ -864,6 +864,8 @@ class Home(MainHandler):
|
||||||
password = sickbeard.PLEX_PASSWORD
|
password = sickbeard.PLEX_PASSWORD
|
||||||
|
|
||||||
cur_result = notifiers.plex_notifier.test_notify(urllib.unquote_plus(host), username, password, server=True)
|
cur_result = notifiers.plex_notifier.test_notify(urllib.unquote_plus(host), username, password, server=True)
|
||||||
|
if '<br />' == cur_result:
|
||||||
|
cur_result += 'Fail: No valid host set to connect with'
|
||||||
final_result = (('Test result for', 'Successful test of')['Fail' not in cur_result]
|
final_result = (('Test result for', 'Successful test of')['Fail' not in cur_result]
|
||||||
+ ' Plex server(s) ... %s<br />\n' % cur_result)
|
+ ' Plex server(s) ... %s<br />\n' % cur_result)
|
||||||
|
|
||||||
|
@ -1117,7 +1119,6 @@ class Home(MainHandler):
|
||||||
return self.redirect('/home/')
|
return self.redirect('/home/')
|
||||||
|
|
||||||
t = PageTemplate(headers=self.request.headers, file='restart.tmpl')
|
t = PageTemplate(headers=self.request.headers, file='restart.tmpl')
|
||||||
t.submenu = self.HomeMenu()
|
|
||||||
|
|
||||||
# restart
|
# restart
|
||||||
sickbeard.events.put(sickbeard.events.SystemEvent.RESTART)
|
sickbeard.events.put(sickbeard.events.SystemEvent.RESTART)
|
||||||
|
@ -1129,16 +1130,11 @@ class Home(MainHandler):
|
||||||
if str(pid) != str(sickbeard.PID):
|
if str(pid) != str(sickbeard.PID):
|
||||||
return self.redirect('/home/')
|
return self.redirect('/home/')
|
||||||
|
|
||||||
updated = sickbeard.versionCheckScheduler.action.update() # @UndefinedVariable
|
if sickbeard.versionCheckScheduler.action.update():
|
||||||
if updated:
|
return self.restart(pid)
|
||||||
# do a hard restart
|
|
||||||
sickbeard.events.put(sickbeard.events.SystemEvent.RESTART)
|
|
||||||
|
|
||||||
t = PageTemplate(headers=self.request.headers, file='restart_bare.tmpl')
|
return self._genericMessage('Update Failed',
|
||||||
return t.respond()
|
'Update wasn\'t successful, not restarting. Check your log for more information.')
|
||||||
else:
|
|
||||||
return self._genericMessage('Update Failed',
|
|
||||||
"Update wasn't successful, not restarting. Check your log for more information.")
|
|
||||||
|
|
||||||
def branchCheckout(self, branch):
|
def branchCheckout(self, branch):
|
||||||
sickbeard.BRANCH = branch
|
sickbeard.BRANCH = branch
|
||||||
|
|
Loading…
Reference in a new issue