diff options
author | RaNaN <Mast3rRaNaN@hotmail.de> | 2009-08-10 10:43:57 +0200 |
---|---|---|
committer | RaNaN <Mast3rRaNaN@hotmail.de> | 2009-08-10 10:43:57 +0200 |
commit | 2e76cf0f532ff89ffa58e5db264a14deb60db6da (patch) | |
tree | 7732fdbdceb957e3596ee275815957ecc2d84045 /Plugins/UploadedTo.py | |
parent | fixed megaupload bug (diff) | |
download | pyload-2e76cf0f532ff89ffa58e5db264a14deb60db6da.tar.xz |
plugin fixes, core config functions
Diffstat (limited to 'Plugins/UploadedTo.py')
-rw-r--r-- | Plugins/UploadedTo.py | 46 |
1 files changed, 32 insertions, 14 deletions
diff --git a/Plugins/UploadedTo.py b/Plugins/UploadedTo.py index 7f30a0519..e163a3230 100644 --- a/Plugins/UploadedTo.py +++ b/Plugins/UploadedTo.py @@ -25,6 +25,35 @@ class UploadedTo(Plugin): self.want_reconnect = None self.multi_dl = False + def prepare(self, thread): + pyfile = self.parent + + self.want_reconnect = False + tries = 0 + + while not pyfile.status.url: + + self.download_html() + + pyfile.status.exists = self.file_exists() + + if not pyfile.status.exists: + raise Exception, "The file was not found on the server." + + pyfile.status.filename = self.get_file_name() + + pyfile.status.waituntil = self.time_plus_wait + pyfile.status.url = self.get_file_url() + pyfile.status.want_reconnect = self.want_reconnect + + thread.wait(self.parent) + + tries += 1 + if tries > 5: + raise Exception, "Error while preparing DL, HTML dump: %s" % self.html + + return True + def download_html(self): url = self.parent.url self.html = self.req.load(url) @@ -39,17 +68,13 @@ class UploadedTo(Plugin): def get_file_url(self): """ returns the absolute downloadable filepath """ - if self.html == None: - self.download_html() - if not self.want_reconnect: + try: file_url_pattern = r".*<form name=\"download_form\" method=\"post\" action=\"(.*)\">" return re.search(file_url_pattern, self.html).group(1) - else: - return False + except: + return None def get_file_name(self): - if self.html == None: - self.download_html() if not self.want_reconnect: file_name = re.search(r"<td><b>\s+(.+)\s", self.html).group(1) file_suffix = re.search(r"</td><td>(\..+)</td></tr>", self.html) @@ -62,14 +87,7 @@ class UploadedTo(Plugin): def file_exists(self): """ returns True or False """ - if self.html == None: - self.download_html() if re.search(r"(File doesn't exist .*)", self.html) != None: return False else: return True - - def wait_until(self): - if self.html == None: - self.download_html() - return self.time_plus_wait |