summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--module/Api.py39
-rw-r--r--module/database/FileDatabase.py23
-rw-r--r--module/remote/create_ttypes.py3
-rw-r--r--module/remote/pyload.thrift5
-rw-r--r--module/remote/ttypes.py16
-rw-r--r--module/remote/ttypes_debug.py6
-rw-r--r--module/web/static/js/models/Package.js1
-rw-r--r--tests/other/test_filedatabase.py (renamed from tests/other/test_database.py)22
8 files changed, 75 insertions, 40 deletions
diff --git a/module/Api.py b/module/Api.py
index d1ccf43c0..0b777a659 100644
--- a/module/Api.py
+++ b/module/Api.py
@@ -696,6 +696,10 @@ class Api(Iface):
def findFiles(self, pattern):
pass
+ @RequirePerm(Permission.All)
+ def findPackages(self, tags):
+ pass
+
#############################
# Modify Downloads
#############################
@@ -751,8 +755,22 @@ class Api(Iface):
#############################
@RequirePerm(Permission.Modify)
- def setPackagePaused(self, pid, paused):
- pass
+ def updatePackage(self, pack):
+ """Allows to modify several package attributes.
+
+ :param pid: package id
+ :param data: :class:`PackageInfo`
+ """
+ pid = pack.pid
+ p = self.core.files.getPackage(pid)
+ if not p: raise PackageDoesNotExists(pid)
+
+ for key, value in data.iteritems():
+ if key == "id": continue
+ setattr(p, key, value)
+
+ p.sync()
+ self.core.files.save()
@RequirePerm(Permission.Modify)
def setPackageFolder(self, pid, path):
@@ -803,23 +821,6 @@ class Api(Iface):
"""
self.core.files.orderFiles(fids, pid, position)
- @RequirePerm(Permission.Modify)
- def setPackageData(self, pid, data):
- """Allows to modify several package attributes.
-
- :param pid: package id
- :param data: dict that maps attribute to desired value
- """
- p = self.core.files.getPackage(pid)
- if not p: raise PackageDoesNotExists(pid)
-
- for key, value in data.iteritems():
- if key == "id": continue
- setattr(p, key, value)
-
- p.sync()
- self.core.files.save()
-
#############################
# User Interaction
#############################
diff --git a/module/database/FileDatabase.py b/module/database/FileDatabase.py
index f3992465c..b303b9b0f 100644
--- a/module/database/FileDatabase.py
+++ b/module/database/FileDatabase.py
@@ -30,6 +30,12 @@ class FileMethods(DatabaseMethods):
return self.c.fetchone()[0]
@queue
+ def downloadcount(self, user=None):
+ """ number of downloads """
+ self.c.execute("SELECT COUNT(*) FROM files WHERE dlstatus != 0")
+ return self.c.fetchone()[0]
+
+ @queue
def queuecount(self, user=None):
""" number of files in queue not finished yet"""
# status not in NA, finished, skipped
@@ -156,12 +162,14 @@ class FileMethods(DatabaseMethods):
return data
@queue
- def getAllPackages(self, root=None, owner=None):
+ def getAllPackages(self, root=None, owner=None, tags=None):
""" Return dict with package information
:param root: optional root to filter
+ :param owner: optional user id
+ :param tags: optional tag list
"""
- qry = ('SELECT pid, name, folder, root, owner, site, comment, password, added, status, packageorder '
+ qry = ('SELECT pid, name, folder, root, owner, site, comment, password, added, tags, status, packageorder '
'FROM packages%s ORDER BY root, packageorder')
if root is None:
@@ -180,9 +188,8 @@ class FileMethods(DatabaseMethods):
data = OrderedDict()
for r in self.c:
data[r[0]] = PackageInfo(
- r[0], r[1], r[2], r[3], r[4], r[5], r[6], r[7], r[8], None, r[9], r[10], stats.get(r[0], zero_stats)
+ r[0], r[1], r[2], r[3], r[4], r[5], r[6], r[7], r[8], r[9].split(","), r[10], r[11], stats.get(r[0], zero_stats)
)
- # TODO: tags
return data
@@ -242,7 +249,7 @@ class FileMethods(DatabaseMethods):
if stats:
stats = self.getPackageStats(pid=pid)
- self.c.execute('SELECT pid, name, folder, root, owner, site, comment, password, added, status, packageorder '
+ self.c.execute('SELECT pid, name, folder, root, owner, site, comment, password, added, tags, status, packageorder '
'FROM packages WHERE pid=?', (pid,))
r = self.c.fetchone()
@@ -250,7 +257,7 @@ class FileMethods(DatabaseMethods):
return None
else:
return PackageInfo(
- r[0], r[1], r[2], r[3], r[4], r[5], r[6], r[7], r[8], None, r[9], r[10], stats.get(r[0], zero_stats) if stats else None
+ r[0], r[1], r[2], r[3], r[4], r[5], r[6], r[7], r[8], r[9].split(","), r[10], r[11], stats.get(r[0], zero_stats) if stats else None
)
@async
@@ -272,8 +279,8 @@ class FileMethods(DatabaseMethods):
@async
def updatePackage(self, p):
- self.c.execute('UPDATE packages SET name=?, folder=?, site=?, comment=?, password=?, status=? WHERE pid=?',
- (p.name, p.folder, p.site, p.comment, p.password, p.status, p.pid))
+ self.c.execute('UPDATE packages SET name=?, folder=?, site=?, comment=?, password=?, tags=?, status=? WHERE pid=?',
+ (p.name, p.folder, p.site, p.comment, p.password, ",".join(p.tags), p.status, p.pid))
# TODO: most modifying methods needs owner argument to avoid checking beforehand
@async
diff --git a/module/remote/create_ttypes.py b/module/remote/create_ttypes.py
index fc4d75d32..c50142322 100644
--- a/module/remote/create_ttypes.py
+++ b/module/remote/create_ttypes.py
@@ -83,6 +83,9 @@ def main():
class BaseObject(object):
\t__slots__ = []
+\tdef __str__(self):
+\t\treturn "<%s %s>" % (self.__class__.__name__, ", ".join("%s=%s" % (k,getattr(self,k)) for k in self.__slots__))
+
""")
dev = open(join(path, "ttypes_debug.py"), "wb")
diff --git a/module/remote/pyload.thrift b/module/remote/pyload.thrift
index 50164c292..183fd3af8 100644
--- a/module/remote/pyload.thrift
+++ b/module/remote/pyload.thrift
@@ -427,7 +427,9 @@ service Pyload {
PackageInfo getPackageInfo(1: PackageID pid) throws (1: PackageDoesNotExists e),
FileInfo getFileInfo(1: FileID fid) throws (1: FileDoesNotExists e),
+
TreeCollection findFiles(1: string pattern),
+ TreeCollection findPackages(1: list<string> tags),
///////////////////////
// Modify Downloads
@@ -445,9 +447,8 @@ service Pyload {
/////////////////////////
// moving package while downloading is not possible, so they will return bool to indicate success
- void setPackagePaused(1: PackageID pid, 2: bool paused) throws (1: PackageDoesNotExists e),
+ void updatePackage(1: PackageInfo pack) throws (1: PackageDoesNotExists e),
bool setPackageFolder(1: PackageID pid, 2: string path) throws (1: PackageDoesNotExists e),
- void setPackageData(1: PackageID pid, 2: map<string, string> data) throws (1: PackageDoesNotExists e),
// as above, this will move files on disk
bool movePackage(1: PackageID pid, 2: PackageID root) throws (1: PackageDoesNotExists e),
diff --git a/module/remote/ttypes.py b/module/remote/ttypes.py
index 4368479fd..eb990f2e8 100644
--- a/module/remote/ttypes.py
+++ b/module/remote/ttypes.py
@@ -6,6 +6,9 @@
class BaseObject(object):
__slots__ = []
+ def __str__(self):
+ return "<%s %s>" % (self.__class__.__name__, ", ".join("%s=%s" % (k,getattr(self,k)) for k in self.__slots__))
+
class DownloadState:
All = 0
Finished = 1
@@ -271,14 +274,13 @@ class PackageStats(BaseObject):
self.sizedone = sizedone
class ProgressInfo(BaseObject):
- __slots__ = ['plugin', 'name', 'statusmsg', 'eta', 'format_eta', 'done', 'total', 'download']
+ __slots__ = ['plugin', 'name', 'statusmsg', 'eta', 'done', 'total', 'download']
- def __init__(self, plugin=None, name=None, statusmsg=None, eta=None, format_eta=None, done=None, total=None, download=None):
+ def __init__(self, plugin=None, name=None, statusmsg=None, eta=None, done=None, total=None, download=None):
self.plugin = plugin
self.name = name
self.statusmsg = statusmsg
self.eta = eta
- self.format_eta = format_eta
self.done = done
self.total = total
self.download = download
@@ -384,6 +386,8 @@ class Iface(object):
pass
def findFiles(self, pattern):
pass
+ def findPackages(self, tags):
+ pass
def freeSpace(self):
pass
def generateAndAddPackages(self, links, paused):
@@ -486,12 +490,8 @@ class Iface(object):
pass
def setInteractionResult(self, iid, result):
pass
- def setPackageData(self, pid, data):
- pass
def setPackageFolder(self, pid, path):
pass
- def setPackagePaused(self, pid, paused):
- pass
def setPassword(self, username, old_password, new_password):
pass
def stop(self):
@@ -510,6 +510,8 @@ class Iface(object):
pass
def updateAccountInfo(self, account):
pass
+ def updatePackage(self, pack):
+ pass
def updateUserData(self, data):
pass
def uploadContainer(self, filename, data):
diff --git a/module/remote/ttypes_debug.py b/module/remote/ttypes_debug.py
index 6ca9e892a..807a8451b 100644
--- a/module/remote/ttypes_debug.py
+++ b/module/remote/ttypes_debug.py
@@ -23,7 +23,7 @@ classes = {
'PackageDoesNotExists' : [int],
'PackageInfo' : [int, basestring, basestring, int, int, basestring, basestring, basestring, int, (list, basestring), int, int, PackageStats, (list, int), (list, int)],
'PackageStats' : [int, int, int, int],
- 'ProgressInfo' : [basestring, basestring, basestring, int, basestring, int, int, (None, DownloadProgress)],
+ 'ProgressInfo' : [basestring, basestring, basestring, int, int, int, (None, DownloadProgress)],
'ServerStatus' : [int, int, int, bool, bool, bool],
'ServiceDoesNotExists' : [basestring, basestring],
'ServiceException' : [basestring],
@@ -54,6 +54,7 @@ methods = {
'deleteFiles': None,
'deletePackages': None,
'findFiles': TreeCollection,
+ 'findPackages': TreeCollection,
'freeSpace': int,
'generateAndAddPackages': (list, int),
'generateDownloadLink': basestring,
@@ -105,9 +106,7 @@ methods = {
'saveConfig': None,
'setConfigHandler': None,
'setInteractionResult': None,
- 'setPackageData': None,
'setPackageFolder': bool,
- 'setPackagePaused': None,
'setPassword': bool,
'stop': None,
'stopAllDownloads': None,
@@ -117,6 +116,7 @@ methods = {
'unpauseServer': None,
'updateAccount': None,
'updateAccountInfo': None,
+ 'updatePackage': None,
'updateUserData': None,
'uploadContainer': int,
}
diff --git a/module/web/static/js/models/Package.js b/module/web/static/js/models/Package.js
index 5a2940c66..64b066dbc 100644
--- a/module/web/static/js/models/Package.js
+++ b/module/web/static/js/models/Package.js
@@ -15,6 +15,7 @@ define(['jquery', 'backbone', 'underscore', 'collections/FileList', 'require'],
comment: "",
password: "",
added: -1,
+ tags: null,
status: -1,
packageorder: -1,
stats: null,
diff --git a/tests/other/test_database.py b/tests/other/test_filedatabase.py
index dd733b4ff..2450e5423 100644
--- a/tests/other/test_database.py
+++ b/tests/other/test_filedatabase.py
@@ -3,7 +3,7 @@
from tests.helper.Stubs import Core
from tests.helper.BenchmarkTest import BenchmarkTest
-from module.Api import DownloadState
+from module.Api import DownloadState, PackageInfo, FileInfo
from module.database import DatabaseBackend
# disable asyncronous queries
@@ -156,12 +156,30 @@ class TestDatabase(BenchmarkTest):
self.db.purgeAll()
assert self.db.filecount() == 0
+ assert self.db.downloadcount() == 0
assert self.db.queuecount() == 0
assert self.db.processcount() == 0
+ def test_update(self):
+ p1 = self.db.addPackage("name", "folder", 0, "password", "site", "comment", self.pstatus, 0)
+ pack = self.db.getPackageInfo(p1)
+ assert isinstance(pack, PackageInfo)
+
+ pack.folder = "new folder"
+ pack.comment = "lol"
+ pack.tags.append("video")
+
+ self.db.updatePackage(pack)
+
+ pack = self.db.getPackageInfo(p1)
+ assert pack.folder == "new folder"
+ assert pack.comment == "lol"
+ assert "video" in pack.tags
+
def assert_file(self, f):
try:
assert f is not None
+ assert isinstance(f, FileInfo)
self.assert_int(f, ("fid", "status", "size", "media", "fileorder", "added", "package", "owner"))
assert f.status in range(5)
assert f.owner == self.owner
@@ -175,12 +193,14 @@ class TestDatabase(BenchmarkTest):
def assert_pack(self, p):
try:
assert p is not None
+ assert isinstance(p, PackageInfo)
self.assert_int(p, ("pid", "root", "added", "status", "packageorder", "owner"))
assert p.pid in self.pids
assert p.owner == self.owner
assert p.status in range(5)
assert p.root in self.pids
assert p.added > 10 ** 6
+ assert isinstance(p.tags, list)
except:
print p
raise