summaryrefslogtreecommitdiffstats
path: root/module/DownloadThread.py
diff options
context:
space:
mode:
authorGravatar mkaay <mkaay@mkaay.de> 2010-05-17 00:01:05 +0200
committerGravatar mkaay <mkaay@mkaay.de> 2010-05-17 00:01:05 +0200
commit32ba2f79389ccf4f7d40197837c02d28bb13261d (patch)
tree893de3556630eaa8242fa0fe3550039cab210b09 /module/DownloadThread.py
parentnew config option (outgoing intreface) (diff)
downloadpyload-32ba2f79389ccf4f7d40197837c02d28bb13261d.tar.xz
new plugin interface test, ShareonlineBiz + SerienjunkiesOrg + MegauploadedCom fix, other stuff
Diffstat (limited to 'module/DownloadThread.py')
-rw-r--r--module/DownloadThread.py25
1 files changed, 22 insertions, 3 deletions
diff --git a/module/DownloadThread.py b/module/DownloadThread.py
index 95e948ec9..95ed88da0 100644
--- a/module/DownloadThread.py
+++ b/module/DownloadThread.py
@@ -117,20 +117,38 @@ class DownloadThread(Thread):
self.parent.parent.pullManager.addEvent(UpdateEvent("file", self.loadedPyFile.id, "queue"))
sleep(0.8)
self.parent.removeThread(self)
-
+
+ def handleNewInterface(self, pyfile):
+ status = pyfile.status
+ plugin = pyfile.plugin
+ status.type = "starting"
+ self.parent.parent.pullManager.addEvent(UpdateEvent("file", pyfile.id, "queue"))
+
+ if plugin.__type__ == "container" or plugin.__type__ == "crypter":
+ status.type = "decrypting"
+ self.parent.parent.pullManager.addEvent(UpdateEvent("file", pyfile.id, "queue"))
+
+ if plugin.__type__ == "container":
+ plugin.decrypt(pyfile.url)
+
+ status.type = "finished"
+
def download(self, pyfile):
+ if hasattr(pyfile.plugin, "__interface__") and pyfile.plugin.__interface__ >= 2:
+ self.handleNewInterface(pyfile)
+ return
status = pyfile.status
status.type = "starting"
self.parent.parent.pullManager.addEvent(UpdateEvent("file", pyfile.id, "queue"))
pyfile.init_download()
-
+
if not pyfile.plugin.prepare(self):
raise Exception, _("File not found")
pyfile.plugin.req.set_timeout(self.parent.parent.config['general']['max_download_time'])
- if pyfile.plugin.__type__ == "container":
+ if pyfile.plugin.__type__ == "container" or pyfile.plugin.__type__ == "crypter":
status.type = "decrypting"
else:
status.type = "downloading"
@@ -167,6 +185,7 @@ class DownloadThread(Thread):
def wait(self, pyfile):
pyfile.status.type = "waiting"
+ self.parent.parent.pullManager.addEvent(UpdateEvent("file", pyfile.id, "queue"))
while (time() < pyfile.status.waituntil):
if self.parent.initReconnect() or self.parent.reconnecting:
pyfile.status.type = "reconnected"