Merge pull request #149 from adam111316/feature/AddCacheDebug

Add hidden cache debug page
This commit is contained in:
adam111316 2015-02-27 09:50:21 +08:00
commit bf0fadeaa2
5 changed files with 129 additions and 0 deletions

View file

@ -12,6 +12,7 @@
* Add Kodi notifier and metadata * Add Kodi notifier and metadata
* Add priority, device, and sound support to Pushover notifier (port from midgetspy/sickbeard) * Add priority, device, and sound support to Pushover notifier (port from midgetspy/sickbeard)
* Fix updating of pull requests * Fix updating of pull requests
* Add hidden cache debug page
[develop changelog] [develop changelog]
* Fix traceback error when using the menu item Manage/Update Kodi * Fix traceback error when using the menu item Manage/Update Kodi

View file

@ -1781,6 +1781,31 @@ h2.day, h2.network {
top:0; top:0;
} }
/* =======================================================================
cache.tmpl
========================================================================== */
#cacheTable {
text-align: center;
}
th.col-name-cache,
td.col-name-cache {
text-align: left;
}
th.col-episodes,
td.col-episodes {
max-width: 250px;
word-wrap: break-word;
}
th.col-cache,
td.col-cache {
width: 20px;
}
/* ======================================================================= /* =======================================================================
config*.tmpl config*.tmpl
========================================================================== */ ========================================================================== */

View file

@ -0,0 +1,85 @@
#import sickbeard
#import os.path
#set global $title='Cache'
#set global $header='Cache'
#set global $sbPath='..'
#set global $topmenu='cache'#
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_top.tmpl')
<style type="text/css">
.sort_data {display:none}
</style>
<script type="text/javascript">
<!--
\$(document).ready(function()
{
\$('#cacheTable:has(tbody tr)').tablesorter({
widgets: ['zebra', 'filter'],
sortList: [[0,1]],
});
#raw
$('.addQTip').each(function () {
$(this).css({'cursor':'help', 'text-shadow':'0px 0px 0.5px #666'});
$(this).qtip({
show: {solo:true},
position: {viewport:$(window), my:'right center', adjust:{ y: -10, x: -15 }},
style: {classes:'qtip-rounded qtip-shadow'}
});
});
#end raw
});
//-->
</script>
#if $varExists('header')
<h1 class="header">$header</h1>
#else
<h1 class="title">$title</h1>
#end if
<table id="cacheTable" class="sickbeardTable tablesorter" cellspacing="1" border="0" cellpadding="0">
<thead>
<tr>
<th class="col-cache">Provider</th>
<th class="col-name-cache">Name</th>
<th class="col-cache">Season</th>
<th class="col-episodes">Episodes</th>
<th class="col-cache">Indexer Id</th>
<th class="col-cache">Url</th>
<th class="col-cache">Time</th>
<th class="col-cache">Quality</th>
<th class="col-cache">Release Group</th>
<th class="col-cache">Version</th>
</tr>
</thead>
<tfoot>
<tr>
<th class="nowrap" colspan="10">&nbsp;</th>
</tr>
</tfoot>
<tbody>
#for $provider in $cacheResults:
#for $hItem in $provider[1]:
<tr>
<td class="col-cache">$provider[0]</td>
<td class="col-name-cache">$hItem['name']</td>
<td class="col-cache">$hItem['season']</td>
<td class="col-episodes">$hItem['episodes']</td>
<td class="col-cache">$hItem['indexerid']</td>
<td class="col-cache"><span title="$hItem['url']" class="addQTip"><img src="$sbRoot/images/info32.png" width="16" height="16" /></span></td>
<td class="col-cache">$hItem['time']</td>
<td class="col-cache">$hItem['quality']</td>
<td class="col-cache">$hItem['release_group']</td>
<td class="col-cache">$hItem['version']</td>
</tr>
#end for
#end for
</tbody>
</table>
#include $os.path.join($sickbeard.PROG_DIR,'gui/slick/interfaces/default/inc_bottom.tmpl')

View file

@ -4627,4 +4627,21 @@ class ApiBuilder(MainHandler):
else: else:
t.apikey = 'api key not generated' t.apikey = 'api key not generated'
return t.respond()
class Cache(MainHandler):
def index(self):
myDB = db.DBConnection('cache.db')
results = []
for provider in sickbeard.providers.sortedProviderList():
try:
sqlResults = myDB.select('SELECT * FROM %s' % provider.cache.providerID)
except:
continue
results.append((provider.name, sqlResults))
t = PageTemplate(headers=self.request.headers, file='cache.tmpl')
t.cacheResults = results
return t.respond() return t.respond()

View file

@ -89,6 +89,7 @@ class WebServer(threading.Thread):
self.app.add_handlers('.*$', [ self.app.add_handlers('.*$', [
(r'%s/api/builder(/?)(.*)' % self.options['web_root'], webserve.ApiBuilder), (r'%s/api/builder(/?)(.*)' % self.options['web_root'], webserve.ApiBuilder),
(r'%s/api(/?.*)' % self.options['web_root'], webapi.Api), (r'%s/api(/?.*)' % self.options['web_root'], webapi.Api),
(r'%s/cache(/?.*)' % self.options['web_root'], webserve.Cache),
(r'%s/config/general(/?.*)' % self.options['web_root'], webserve.ConfigGeneral), (r'%s/config/general(/?.*)' % self.options['web_root'], webserve.ConfigGeneral),
(r'%s/config/search(/?.*)' % self.options['web_root'], webserve.ConfigSearch), (r'%s/config/search(/?.*)' % self.options['web_root'], webserve.ConfigSearch),
(r'%s/config/providers(/?.*)' % self.options['web_root'], webserve.ConfigProviders), (r'%s/config/providers(/?.*)' % self.options['web_root'], webserve.ConfigProviders),