summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--module/FileDatabase.py89
-rw-r--r--module/PluginManager.py2
-rw-r--r--module/plugins/hooks/MultiHome.py7
3 files changed, 63 insertions, 35 deletions
diff --git a/module/FileDatabase.py b/module/FileDatabase.py
index 2f9715d0f..e2b7a47a4 100644
--- a/module/FileDatabase.py
+++ b/module/FileDatabase.py
@@ -347,40 +347,53 @@ class FileHandler:
@change
def setPackageLocation(self, id, queue):
"""push package to queue"""
- pack = self.getPackage(id)
+
+ pack = self.db.getPackage(id)
e = RemoveEvent("pack", id, "collector" if not pack.queue else "queue")
self.core.pullManager.addEvent(e)
+ self.db.clearPackageOrder(pack)
+
+ pack = self.db.getPackage(id)
+
pack.queue = queue
- pack.sync()
- self.db.commit()
+ self.db.updatePackage(pack)
+
+ self.db.reorderPackage(pack, -1, True)
- e = InsertEvent("pack", id, -1, "collector" if not pack.queue else "queue")
+ self.db.commit()
+ self.releasePackage(id)
+ pack = self.getPackage(id)
+ e = InsertEvent("pack", id, pack.order, "collector" if not pack.queue else "queue")
self.core.pullManager.addEvent(e)
@change
def reorderPackage(self, id, position):
- e = RemoveEvent("pack", id, "collector" if not self.db.getPackage(id).queue else "queue")
+ p = self.db.getPackage(id)
+
+ e = RemoveEvent("pack", id, "collector" if not p.queue else "queue")
self.core.pullManager.addEvent(e)
- self.db.reorderPackage(id, position)
+ self.db.reorderPackage(p, position)
self.db.commit()
- e = ReloadAllEvent("collector" if not self.db.getPackage(id).package().queue else "queue")
+ e = ReloadAllEvent("collector" if not p.queue else "queue")
self.core.pullManager.addEvent(e)
@change
def reorderFile(self, id, position):
- e = RemoveEvent("file", id, "collector" if not self.db.getFile(id).package().queue else "queue")
+ f = self.db.getFile(id)
+
+ e = RemoveEvent("file", id, "collector" if not f.package().queue else "queue")
self.core.pullManager.addEvent(e)
- self.db.reorderFile(id, position)
+ self.db.reorderFile(f, position)
self.db.commit()
- e = ReloadAllEvent("collector" if not self.db.getFile(id).queue else "queue")
+ e = ReloadAllEvent("collector" if not f.package().queue else "queue")
self.core.pullManager.addEvent(e)
#########################################################################
@@ -476,14 +489,20 @@ class FileDatabaseBackend(Thread):
return len(r)
def _nextPackageOrder(self, queue=0):
- self.c.execute('SELECT max(packageorder) FROM packages WHERE queue=?', (queue, ))
- r = self.c.fetchone()
- return r[0] if r[0] else 0
+ self.c.execute('SELECT packageorder FROM packages WHERE queue=?', (queue, ))
+ rs = self.c.fetchall()
+ o = -1
+ for r in rs:
+ if r[0] > o: o = r[0]
+ return o+1
def _nextFileOrder(self, package):
- self.c.execute('SELECT max(linkorder) FROM links WHERE package=?', (package, ))
- r = self.c.fetchone()
- return r[0] if r[0] else 0
+ self.c.execute('SELECT linkorder FROM links WHERE package=?', (package, ))
+ rs = self.c.fetchall()
+ o = -1
+ for r in rs:
+ if r[0] > o: o = r[0]
+ return o+1
@queue
def addLink(self, url, name, plugin, package):
@@ -507,14 +526,18 @@ class FileDatabaseBackend(Thread):
@queue
def deletePackage(self, id):
+ p = self.getPackage(id)
self.c.execute('DELETE FROM links WHERE package=?', (str(id), ))
self.c.execute('DELETE FROM packages WHERE id=?', (str(id), ))
+ self.c.execute('UPDATE packages SET packageorder=packageorder-1 WHERE packageorder > ? AND queue=?', ( p.order, p.queue) )
@queue
def deleteLink(self, id):
+ f = self.getFile(id)
self.c.execute('DELETE FROM links WHERE id=?', (str(id), ))
+ self.c.execute('UPDATE links SET linkorder=linkorder-1 WHERE linkorder > ? AND package=?', ( f.order, str(f.packageid)) )
@queue
@@ -531,7 +554,7 @@ class FileDatabaseBackend(Thread):
}
"""
- self.c.execute('SELECT l.id,l.url,l.name,l.size,l.status,l.error,l.plugin,l.package,l.linkorder FROM links as l INNER JOIN packages as p ON l.package=p.id WHERE p.queue=? ORDER BY l.id', (q, ))
+ self.c.execute('SELECT l.id,l.url,l.name,l.size,l.status,l.error,l.plugin,l.package,l.linkorder FROM links as l INNER JOIN packages as p ON l.package=p.id WHERE p.queue=? ORDER BY p.packageorder, l.linkorder', (q, ))
data = {}
for r in self.c:
data[str(r[0])] = {
@@ -563,7 +586,7 @@ class FileDatabaseBackend(Thread):
id: {'name': name ... 'links': {} }, ...
}
"""
- self.c.execute('SELECT id,name,folder,site,password,queue,packageorder,priority FROM packages WHERE queue=? ORDER BY id', str(q))
+ self.c.execute('SELECT id,name,folder,site,password,queue,packageorder,priority FROM packages WHERE queue=? ORDER BY packageorder', str(q))
data = {}
for r in self.c:
@@ -588,7 +611,7 @@ class FileDatabaseBackend(Thread):
@queue
def getPackageData(self, id):
"""get package data"""
- self.c.execute('SELECT id,url,name,size,status,error,plugin,package,linkorder FROM links WHERE package=? ORDER BY id', (str(id),))
+ self.c.execute('SELECT id,url,name,size,status,error,plugin,package,linkorder FROM links WHERE package=? ORDER BY linkorder', (str(id),))
data = {}
for r in self.c:
@@ -612,28 +635,32 @@ class FileDatabaseBackend(Thread):
def updateLink(self, f):
self.c.execute('UPDATE links SET url=?,name=?,size=?,status=?,error=?,package=? WHERE id=?', (f.url, f.name, f.size, f.status, f.error, str(f.packageid), str(f.id)))
- @async
+ @queue
def updatePackage(self, p):
self.c.execute('UPDATE packages SET name=?,folder=?,site=?,password=?,queue=?,priority=? WHERE id=?', (p.name, p.folder, p.site, p.password, p.queue, p.priority, str(p.id)))
- @async
- def reorderPackage(self, id, position):
- p = self.getPackage(id)
- self.c.execute('UPDATE packages SET packageorder=packageorder-1 WHERE packageorder > ? AND queue=?', ( p.order, p.queue) )
- self.c.execute('UPDATE packages SET packageorder=packageorder+1 WHERE packageorder >= ? AND queue=?', ( position, p.queue) )
+ @queue
+ def reorderPackage(self, p, position, noMove=False):
+ if position == -1:
+ position = self._nextPackageOrder(p.queue)
+ if not noMove:
+ self.c.execute('UPDATE packages SET packageorder=packageorder-1 WHERE packageorder > ? AND queue=? AND packageorder > 0', ( p.order, p.queue) )
+ self.c.execute('UPDATE packages SET packageorder=packageorder+1 WHERE packageorder >= ? AND queue=? AND packageorder > 0', ( position, p.queue) )
self.c.execute('UPDATE packages SET packageorder=? WHERE id=?', ( position, str(p.id) ) )
- p.order = position
- p.sync()
- @async
- def reorderLink(self, id, position):
- f = self.getFile(id)
+ @queue
+ def reorderLink(self, f, position):
self.c.execute('UPDATE links SET linkorder=linkorder-1 WHERE linkorder > ? AND package=?', ( f.order, str(f.packageid) ) )
self.c.execute('UPDATE links SET linkorder=linkorder+1 WHERE linkorder >= ? AND package=?', ( position, str(f.packageid) ) )
self.c.execute('UPDATE links SET linkorder=? WHERE id=?', ( position, str(f.id) ) )
f.order = position
f.sync()
+ @queue
+ def clearPackageOrder(self, p):
+ self.c.execute('UPDATE packages SET packageorder=? WHERE id=?', ( -1, str(p.id) ) )
+ self.c.execute('UPDATE packages SET packageorder=packageorder-1 WHERE packageorder > ? AND queue=? AND id != ?', ( p.order, p.queue, str(p.id)) )
+
@async
def restartFile(self, id):
self.c.execute('UPDATE links SET status=3 WHERE id=?', ( str(id), ) )
@@ -680,7 +707,7 @@ class FileDatabaseBackend(Thread):
cmd += ")"
- cmd = "SELECT l.id FROM links as l INNER JOIN packages as p ON l.package=p.id WHERE p.queue=1 AND l.plugin NOT IN %s AND l.status IN (2,3,6) LIMIT 5" % cmd
+ cmd = "SELECT l.id FROM links as l INNER JOIN packages as p ON l.package=p.id WHERE p.queue=1 AND l.plugin NOT IN %s AND l.status IN (2,3,6) Order BY p.packageorder, l.linkorder LIMIT 5" % cmd
self.c.execute(cmd) # very bad!
diff --git a/module/PluginManager.py b/module/PluginManager.py
index 6cff2d50f..6815fed52 100644
--- a/module/PluginManager.py
+++ b/module/PluginManager.py
@@ -262,4 +262,4 @@ if __name__ == "__main__":
b = time()
print b-a ,"s"
- \ No newline at end of file
+
diff --git a/module/plugins/hooks/MultiHome.py b/module/plugins/hooks/MultiHome.py
index 9e2bcbe5f..cfea5952d 100644
--- a/module/plugins/hooks/MultiHome.py
+++ b/module/plugins/hooks/MultiHome.py
@@ -25,7 +25,7 @@ class MultiHome(Hook):
__version__ = "0.1"
__description__ = """ip address changer"""
__config__ = [ ("activated", "bool", "Activated" , "False"),
- ("interfaces", "str", "Interfaces" , "") ]
+ ("interfaces", "str", "Interfaces" , "None") ]
__author_name__ = ("mkaay")
__author_mail__ = ("mkaay@mkaay.de")
@@ -51,8 +51,9 @@ class MultiHome(Hook):
oldGetRequest = requestFactory.getRequest
def getRequest(pluginName, account=None, type="HTTP"):
iface = self.bestInterface(pluginName, account)
- iface.useFor(pluginName, account)
- requestFactory.iface = iface.adress
+ if iface:
+ iface.useFor(pluginName, account)
+ requestFactory.iface = iface.adress
return oldGetRequest(pluginName, account, type)
requestFactory.getRequest = getRequest