Fixes for DB issues

This commit is contained in:
echel0n 2014-06-07 15:35:16 -07:00
parent d00d55fdfc
commit a1da7df12e
17 changed files with 67 additions and 56 deletions

View file

@ -1,4 +1,5 @@
#import sickbeard
#import psutil
#from sickbeard import db
#import os.path
#set global $title="Configuration"
@ -14,6 +15,17 @@
<h1 class="title">$title</h1>
#end if
#set cpu_usage = $psutil.cpu_percent()
#set ram = $psutil.phymem_usage()
#set ram_total = $ram.total / 2**20
#set ram_used = $ram.used / 2**20
#set ram_free = $ram.free / 2**20
#set ram_percent_used = $ram.percent
#set disk = $psutil.disk_usage('/')
#set disk_total = $disk.total / 2**30
#set disk_used = $disk.used / 2**30
#set disk_free = $disk.free / 2**30
#set disk_percent_used = $disk.percent
<div id="summary" class="align-left">
<table class="infoTable" cellspacing="1" border="0" cellpadding="0">
@ -25,6 +37,7 @@
#end if
<font color="red">You are using BETA software</font>
</td></tr>
<tr><td class="infoTableHeader">Memory Used: </td><td class="infoTableCell">$ram_percent_used</td></tr>
<tr><td class="infoTableHeader">SR Config file: </td><td class="infoTableCell">$sickbeard.CONFIG_FILE</td></tr>
<tr><td class="infoTableHeader">SR Database file: </td><td class="infoTableCell">$db.dbFilename()</td></tr>
<tr><td class="infoTableHeader">SR Cache Dir: </td><td class="infoTableCell">$sickbeard.CACHE_DIR</td></tr>

View file

@ -343,8 +343,8 @@ class BTNCache(tvcache.TVCache):
cl.append(ci)
if cl:
myDB = self._getDB()
myDB.mass_action(cl)
with self._getDB() as myDB:
myDB.mass_action(cl)
else:
raise AuthException(

View file

@ -255,8 +255,8 @@ class HDBitsCache(tvcache.TVCache):
ql.append(ci)
if ql:
myDB = self._getDB()
myDB.mass_action(ql)
with self._getDB() as myDB:
myDB.mass_action(ql)
else:
raise exceptions.AuthException(

View file

@ -377,8 +377,8 @@ class HDTorrentsCache(tvcache.TVCache):
cl.append(ci)
if cl:
myDB = self._getDB()
myDB.mass_action(cl)
with self._getDB() as myDB:
myDB.mass_action(cl)
def _parseItem(self, item):

View file

@ -318,8 +318,8 @@ class IPTorrentsCache(tvcache.TVCache):
cl.append(ci)
if cl:
myDB = self._getDB()
myDB.mass_action(cl)
with self._getDB() as myDB:
myDB.mass_action(cl)
def _parseItem(self, item):

View file

@ -455,8 +455,8 @@ class KATCache(tvcache.TVCache):
cl.append(ci)
if cl:
myDB = self._getDB()
myDB.mass_action(cl)
with self._getDB() as myDB:
myDB.mass_action(cl)
def _parseItem(self, item):

View file

@ -342,8 +342,8 @@ class NewznabCache(tvcache.TVCache):
ql.append(ci)
if ql:
myDB = self._getDB()
myDB.mass_action(ql)
with self._getDB() as myDB:
myDB.mass_action(ql)
else:
raise AuthException(

View file

@ -367,8 +367,8 @@ class NextGenCache(tvcache.TVCache):
cl.append(ci)
if cl:
myDB = self._getDB()
myDB.mass_action(cl)
with self._getDB() as myDB:
myDB.mass_action(cl)
def _parseItem(self, item):

View file

@ -340,8 +340,8 @@ class PublicHDCache(tvcache.TVCache):
ql.append(ci)
if ql:
myDB = self._getDB()
myDB.mass_action(ql)
with self._getDB() as myDB:
myDB.mass_action(ql)
def _parseItem(self, item):

View file

@ -362,8 +362,8 @@ class SCCCache(tvcache.TVCache):
cl.append(ci)
if cl:
myDB = self._getDB()
myDB.mass_action(cl)
with self._getDB() as myDB:
myDB.mass_action(cl)
def _parseItem(self, item):

View file

@ -302,8 +302,8 @@ class SpeedCDCache(tvcache.TVCache):
ql.append(ci)
if ql:
myDB = self._getDB()
myDB.mass_action(ql)
with self._getDB() as myDB:
myDB.mass_action(ql)
def _parseItem(self, item):

View file

@ -435,8 +435,8 @@ class ThePirateBayCache(tvcache.TVCache):
cl.append(ci)
if cl:
myDB = self._getDB()
myDB.mass_action(cl)
with self._getDB() as myDB:
myDB.mass_action(cl)
def _parseItem(self, item):

View file

@ -326,8 +326,8 @@ class TorrentDayCache(tvcache.TVCache):
cl.append(ci)
if cl:
myDB = self._getDB()
myDB.mass_action(cl)
with self._getDB() as myDB:
myDB.mass_action(cl)
def _parseItem(self, item):

View file

@ -321,8 +321,8 @@ class TorrentLeechCache(tvcache.TVCache):
cl.append(ci)
if cl:
myDB = self._getDB()
myDB.mass_action(cl)
with self._getDB() as myDB:
myDB.mass_action(cl)
def _parseItem(self, item):

View file

@ -693,4 +693,5 @@ def fix_xem_numbering(indexer_id, indexer):
update_scene_absolute_number = False
if ql:
myDB.mass_action(ql)
with db.DBConnection() as myDB:
myDB.mass_action(ql)

View file

@ -203,7 +203,7 @@ class TVShow(object):
if self.is_anime and absolute_number and not season and not episode:
with db.DBConnection() as myDB:
sql = "SELECT * FROM tv_episodes WHERE showid = ? and absolute_number = ? and season != 0"
sqlResults = myDB.select(sql, [self.indexerid, absolute_number])
sqlResults = myDB.select(sql, [self.indexerid, absolute_number])
if len(sqlResults) == 1:
episode = int(sqlResults[0]["episode"])

View file

@ -82,11 +82,10 @@ class TVCache():
if not self.shouldClearCache():
return
myDB = self._getDB()
curDate = datetime.date.today() - datetime.timedelta(weeks=1)
myDB.action("DELETE FROM [" + self.providerID + "] WHERE time < ?", [int(time.mktime(curDate.timetuple()))])
with self._getDB() as myDB:
myDB.action("DELETE FROM [" + self.providerID + "] WHERE time < ?", [int(time.mktime(curDate.timetuple()))])
def _getRSSData(self):
@ -127,8 +126,8 @@ class TVCache():
cl.append(ci)
if cl:
myDB = self._getDB()
myDB.mass_action(cl)
with self._getDB() as myDB:
myDB.mass_action(cl)
else:
raise AuthException(
@ -194,8 +193,8 @@ class TVCache():
def _getLastUpdate(self):
myDB = self._getDB()
sqlResults = myDB.select("SELECT time FROM lastUpdate WHERE provider = ?", [self.providerID])
with self._getDB() as myDB:
sqlResults = myDB.select("SELECT time FROM lastUpdate WHERE provider = ?", [self.providerID])
if sqlResults:
lastTime = int(sqlResults[0]["time"])
@ -207,8 +206,8 @@ class TVCache():
return datetime.datetime.fromtimestamp(lastTime)
def _getLastSearch(self):
myDB = self._getDB()
sqlResults = myDB.select("SELECT time FROM lastSearch WHERE provider = ?", [self.providerID])
with self._getDB() as myDB:
sqlResults = myDB.select("SELECT time FROM lastSearch WHERE provider = ?", [self.providerID])
if sqlResults:
lastTime = int(sqlResults[0]["time"])
@ -224,19 +223,19 @@ class TVCache():
if not toDate:
toDate = datetime.datetime.today()
myDB = self._getDB()
myDB.upsert("lastUpdate",
{'time': int(time.mktime(toDate.timetuple()))},
{'provider': self.providerID})
with self._getDB() as myDB:
myDB.upsert("lastUpdate",
{'time': int(time.mktime(toDate.timetuple()))},
{'provider': self.providerID})
def setLastSearch(self, toDate=None):
if not toDate:
toDate = datetime.datetime.today()
myDB = self._getDB()
myDB.upsert("lastSearch",
{'time': int(time.mktime(toDate.timetuple()))},
{'provider': self.providerID})
with self._getDB() as myDB:
myDB.upsert("lastSearch",
{'time': int(time.mktime(toDate.timetuple()))},
{'provider': self.providerID})
lastUpdate = property(_getLastUpdate)
lastSearch = property(_getLastSearch)
@ -316,25 +315,23 @@ class TVCache():
return neededEps
def listPropers(self, date=None, delimiter="."):
myDB = self._getDB()
with self._getDB() as myDB:
sql = "SELECT * FROM [" + self.providerID + "] WHERE name LIKE '%.PROPER.%' OR name LIKE '%.REPACK.%'"
sql = "SELECT * FROM [" + self.providerID + "] WHERE name LIKE '%.PROPER.%' OR name LIKE '%.REPACK.%'"
if date != None:
sql += " AND time >= " + str(int(time.mktime(date.timetuple())))
if date != None:
sql += " AND time >= " + str(int(time.mktime(date.timetuple())))
return filter(lambda x: x['indexerid'] != 0, myDB.select(sql))
return filter(lambda x: x['indexerid'] != 0, myDB.select(sql))
def findNeededEpisodes(self, episodes, manualSearch=False):
neededEps = {}
cacheDB = self._getDB()
for epObj in episodes:
sqlResults = cacheDB.select(
"SELECT * FROM [" + self.providerID + "] WHERE indexerid = ? AND season = ? AND episodes LIKE ?",
[epObj.show.indexerid, epObj.season, "%|" + str(epObj.episode) + "|%"])
with self._getDB() as myDB:
sqlResults = myDB.select(
"SELECT * FROM [" + self.providerID + "] WHERE indexerid = ? AND season = ? AND episodes LIKE ?",
[epObj.show.indexerid, epObj.season, "%|" + str(epObj.episode) + "|%"])
# for each cache entry
for curResult in sqlResults: