summaryrefslogtreecommitdiffstats
path: root/module/remote/thriftbackend/Handler.py
diff options
context:
space:
mode:
Diffstat (limited to 'module/remote/thriftbackend/Handler.py')
-rw-r--r--module/remote/thriftbackend/Handler.py46
1 files changed, 31 insertions, 15 deletions
diff --git a/module/remote/thriftbackend/Handler.py b/module/remote/thriftbackend/Handler.py
index da77b8ed2..6eb2a8bc6 100644
--- a/module/remote/thriftbackend/Handler.py
+++ b/module/remote/thriftbackend/Handler.py
@@ -15,7 +15,7 @@ class Handler(Iface):
def _convertPyFile(self, p):
f = FileData(p["id"], p["url"], p["name"], p["plugin"], p["size"],
p["format_size"], p["status"], p["statusmsg"],
- p["package"], p["error"], p["order"])
+ p["package"], p["error"], p["order"], p["progress"])
return f
def _convertConfigFormat(self, c):
@@ -23,14 +23,14 @@ class Handler(Iface):
for sectionName, sub in c.iteritems():
section = ConfigSection()
section.name = sectionName
- section.decription = sub["desc"]
+ section.description = sub["desc"]
items = []
for key, data in sub.iteritems():
if key == "desc":
continue
item = ConfigItem()
item.name = key
- item.decription = data["desc"]
+ item.description = data["desc"]
item.value = str(data["value"])
item.type = data["type"]
items.append(item)
@@ -82,13 +82,15 @@ class Handler(Iface):
serverStatus.active = status["activ"]
serverStatus.queue = status["queue"]
serverStatus.total = status["total"]
- serverStatus.speed = status["speed"]
+ serverStatus.speed = 0
+ for pyfile in [x.active for x in self.core.threadManager.threads if x.active and x.active != "quit"]:
+ serverStatus.speed += pyfile.getSpeed() #bytes/s
serverStatus.download = status["download"]
serverStatus.reconnect = status["reconnect"]
return serverStatus
def freeSpace(self):
- return self.serverMethods.free_space()
+ return self.core.freeSpace() #bytes
def getServerVersion(self):
return self.serverMethods.get_server_version()
@@ -104,7 +106,8 @@ class Handler(Iface):
Parameters:
- offset
"""
- return list(self.serverMethods.restart(offset))
+ log = self.serverMethods.get_log(offset)
+ return log or []
def checkURL(self, urls):
"""
@@ -135,7 +138,7 @@ class Handler(Iface):
status = DownloadInfo()
status.id = pyfile.id
status.name = pyfile.name
- status.speed = pyfile.getSpeed() / 1024
+ status.speed = pyfile.getSpeed() #bytes
status.eta = pyfile.getETA()
status.format_eta = pyfile.formatETA()
status.kbleft = pyfile.getBytesLeft() #holded for backward comp.
@@ -187,9 +190,8 @@ class Handler(Iface):
Parameters:
- fid
"""
- rawData = self.serverMethods.get_file_data(fid)
+ rawData = self.serverMethods.get_file_data(fid).values()[0]
fdata = self._convertPyFile(rawData)
- fdata.progress = rawData["progress"]
return fdata
def deleteFiles(self, fids):
@@ -369,6 +371,8 @@ class Handler(Iface):
packs = self.serverMethods.get_collector()
for pid in packs:
pack = self.serverMethods.get_package_data(pid)
+ while pack["order"] in order.keys():
+ pack["order"] += 1
order[pack["order"]] = pack["id"]
return order
@@ -412,26 +416,35 @@ class Handler(Iface):
self.serverMethods.set_captcha_result(tid, result)
#events
- def getEvents(self):
- events = self.serverMethods.get_events()
+ def getEvents(self, uuid):
+ events = self.serverMethods.get_events(uuid)
newEvents = []
+ def convDest(d):
+ return Destination.Queue if d == "queue" else Destination.Collector
for e in events:
event = Event()
+ event.event = e[0]
if e[0] in ("update", "remove", "insert"):
event.id = e[3]
event.type = ElementType.Package if e[2] == "pack" else ElementType.File
- event.destination = e[1]
+ event.destination = convDest(e[1])
elif e[0] == "order":
if e[1]:
event.id = e[1]
event.type = ElementType.Package if e[2] == "pack" else ElementType.File
- event.destination = e[3]
+ event.destination = convDest(e[3])
+ elif e[0] == "reload":
+ event.destination = convDest(e[1])
newEvents.append(event)
return newEvents
#accounts
- def getAccounts(self):
- accs = self.serverMethods.get_accounts()
+ def getAccounts(self, refresh):
+ """
+ Parameters:
+ - refresh
+ """
+ accs = self.serverMethods.get_accounts(False, refresh)
accounts = []
for group in accs.values():
for acc in group:
@@ -446,6 +459,9 @@ class Handler(Iface):
account.type = acc["type"]
accounts.append(account)
return accounts
+
+ def getAccountTypes(self):
+ return self.serverMethods.get_accounts().keys()
def updateAccounts(self, data):
"""