diff options
-rw-r--r-- | module/AccountManager.py | 2 | ||||
-rw-r--r-- | module/plugins/Account.py | 8 | ||||
-rw-r--r-- | module/plugins/Plugin.py | 4 | ||||
-rw-r--r-- | module/plugins/accounts/FreakshareCom.py | 53 | ||||
-rw-r--r-- | module/plugins/accounts/NetloadIn.py | 15 | ||||
-rw-r--r-- | module/plugins/hoster/FreakshareCom.py | 13 | ||||
-rw-r--r-- | module/plugins/hoster/MegauploadCom.py | 15 | ||||
-rw-r--r-- | module/plugins/hoster/RapidshareCom.py | 4 | ||||
-rw-r--r-- | module/web/pyload/views.py | 2 |
9 files changed, 98 insertions, 18 deletions
diff --git a/module/AccountManager.py b/module/AccountManager.py index 5dedacf3c..c155edfae 100644 --- a/module/AccountManager.py +++ b/module/AccountManager.py @@ -103,7 +103,7 @@ class AccountManager(): elif line.startswith("@"): option = line[1:].split() - self.accounts[plugin][name]["options"][option[0]] = [option[1]] if len(option) < 3 else option[1:] + self.accounts[plugin][name]["options"][option[0]] = True if len(option) < 2 else ([option[1]] if len(option) < 3 else option[1:]) elif ":" in line: name, sep, pw = line.partition(":") diff --git a/module/plugins/Account.py b/module/plugins/Account.py index d93ff7e08..d0beaa8dc 100644 --- a/module/plugins/Account.py +++ b/module/plugins/Account.py @@ -47,11 +47,11 @@ class Account(): try: self.login(user, data) except WrongPassword: - self.core.log.warning(_("Could not login with account %s | %s") % (user, _("Wrong Password"))) + self.core.log.warning(_("Could not login with %s account %s | %s") % (self.__name__, user, _("Wrong Password"))) data["valid"] = False except Exception, e: - self.core.log.warning(_("Could not login with account %s | %s") % (user, e)) + self.core.log.warning(_("Could not login with %s account %s | %s") % (self.__name__, user, e)) data["valid"] = False if self.core.debug: print_exc() @@ -86,6 +86,8 @@ class Account(): self.core.log.debug("Get %s Account Info for %s" % (self.__name__, name)) try: infos = self.loadAccountInfo(name) + if not type(infos) == dict: + raise Exception("Wrong return format") except Exception, e: infos = {"error": str(e)} self.core.log.debug("Account Info: %s" % str(infos)) @@ -101,7 +103,7 @@ class Account(): #"password": self.accounts[name]["password"], #@XXX: security "options": self.accounts[name]["options"], "valid": self.accounts[name]["valid"], - "trafficleft": None, # -1 for unlimited + "trafficleft": None, # in kb, -1 for unlimited "maxtraffic": None, "type": self.__name__, } diff --git a/module/plugins/Plugin.py b/module/plugins/Plugin.py index 2b2ee2414..55faa37e1 100644 --- a/module/plugins/Plugin.py +++ b/module/plugins/Plugin.py @@ -121,7 +121,9 @@ class Plugin(object): """ handles important things to do before starting """ self.thread = thread - if not self.account: + if self.account: + self.multiDL = True #every hoster with account should provides multiple downloads + else: self.req.clearCookies() if self.core.config["proxy"]["activated"]: diff --git a/module/plugins/accounts/FreakshareCom.py b/module/plugins/accounts/FreakshareCom.py new file mode 100644 index 000000000..ba9566522 --- /dev/null +++ b/module/plugins/accounts/FreakshareCom.py @@ -0,0 +1,53 @@ +# -*- coding: utf-8 -*- + +""" + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 3 of the License, + or (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + See the GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, see <http://www.gnu.org/licenses/>. + + @author: RaNaN +""" +import re +from time import strptime, mktime + +from module.plugins.Account import Account + +class FreakshareCom(Account): + __name__ = "FreakshareCom" + __version__ = "0.1" + __type__ = "account" + __description__ = """freakshare.com account plugin""" + __author_name__ = ("RaNaN") + __author_mail__ = ("RaNaN@pyload.org") + + def loadAccountInfo(self, user): + req = self.getAccountRequest(user) + page = req.load("http://freakshare.com/") + + validuntil = r"ltig bis:</td>\s*<td><b>([0-9 \-:.]+)</b></td>" + validuntil = re.search(validuntil, page, re.MULTILINE) + validuntil = validuntil.group(1).strip() + validuntil = mktime(strptime(validuntil, "%d.%m.%Y - %H:%M")) + + traffic = r"Traffic verbleibend:</td>\s*<td>([^<]+)" + traffic = re.search(traffic, page, re.MULTILINE) + traffic = traffic.group(1).strip() + traffic = self.parseTraffic(traffic) + + return {"validuntil": validuntil, "trafficleft": traffic} + + def login(self, user, data): + req = self.getAccountRequest(user) + page = req.load("http://freakshare.com/login.html", None, { "submit" : "Login", "user" : user, "pass" : data['password']}, cookies=True) + + if "Falsche Logindaten!" in page or "Wrong Username or Password!" in page: + self.wrongPassword() diff --git a/module/plugins/accounts/NetloadIn.py b/module/plugins/accounts/NetloadIn.py index 28b3a1c56..16e06b688 100644 --- a/module/plugins/accounts/NetloadIn.py +++ b/module/plugins/accounts/NetloadIn.py @@ -18,6 +18,8 @@ """ from module.plugins.Account import Account +import re +from time import time class NetloadIn(Account): __name__ = "NetloadIn" @@ -26,8 +28,17 @@ class NetloadIn(Account): __description__ = """netload.in account plugin""" __author_name__ = ("RaNaN") __author_mail__ = ("RaNaN@pyload.org") + + def loadAccountInfo(self, user): + req = self.getAccountRequest(user) + page = req.load("http://netload.in/index.php?id=2") + left = r">(\d+) Tage, (\d+) Stunden<" + left = re.search(left, page) + validuntil = time() + int(left.group(1)) * 24 * 60 * 60 + int(left.group(2)) * 60 * 60 + return {"validuntil": validuntil, "trafficleft": -1} def login(self, user, data): req = self.getAccountRequest(user) - req.load("http://netload.in/index.php", None, { "txtuser" : user, "txtpass" : data['password'], "txtcheck" : "login", "txtlogin" : ""}, cookies=True) - + page = req.load("http://netload.in/index.php", None, { "txtuser" : user, "txtpass" : data['password'], "txtcheck" : "login", "txtlogin" : ""}, cookies=True) + if "password or it might be invalid!" in page: + self.wrongPassword() diff --git a/module/plugins/hoster/FreakshareCom.py b/module/plugins/hoster/FreakshareCom.py index 524081002..bbc22ac98 100644 --- a/module/plugins/hoster/FreakshareCom.py +++ b/module/plugins/hoster/FreakshareCom.py @@ -23,10 +23,16 @@ class FreakshareCom(Hoster): def process(self, pyfile): pyfile.url = pyfile.url.replace("freakshare.net/","freakshare.com/") - self.prepare() - self.get_file_url() + if self.account: + self.html = self.load(pyfile.url, cookies=False) + pyfile.name = self.get_file_name() + self.download(pyfile.url) - self.download(self.pyfile.url, post=self.req_opts) + else: + self.prepare() + self.get_file_url() + + self.download(self.pyfile.url, post=self.req_opts) def prepare(self): @@ -48,7 +54,6 @@ class FreakshareCom(Hoster): return True def download_html(self): - url = self.pyfile.url.replace("freakshare.net/","freakshare.com/") self.html = self.load(url, cookies=True) def get_file_url(self): diff --git a/module/plugins/hoster/MegauploadCom.py b/module/plugins/hoster/MegauploadCom.py index 4c851a5b2..b913976a0 100644 --- a/module/plugins/hoster/MegauploadCom.py +++ b/module/plugins/hoster/MegauploadCom.py @@ -76,17 +76,19 @@ class MegauploadCom(Hoster): pyfile.name = self.get_file_name() self.download(self.get_file_url()) + check = self.checkDownload({"limit": "Download limit exceeded"}) + if check == "limit": + wait = self.load("http://www.megaupload.com/?c=premium&l=1") + wait = re.search(r"Please wait (\d+) minutes", wait).group(1) + self.log.info(_("Megaupload: waiting %d minues") % wait) + self.setWait(int(wait)*60, True) + self.wait() + self.process(pyfile) else: self.download_api() pyfile.name = self.get_file_name() self.download(pyfile.url) - check = self.checkDownload({"limit": "Download limit exceeded"}) #@TODO catch it earlier in html pages if possible - if check == "limit": - self.setWait(3600, True) - self.wait() - self.process(pyfile) - def download_html(self): for i in range(5): self.html[0] = self.load(self.pyfile.url) @@ -117,6 +119,7 @@ class MegauploadCom(Hoster): if re.search(r"Waiting time before each download begins", self.html[1]) is not None: break + print self.html[0] def download_api(self): diff --git a/module/plugins/hoster/RapidshareCom.py b/module/plugins/hoster/RapidshareCom.py index 40fe05eeb..0e3d2e74d 100644 --- a/module/plugins/hoster/RapidshareCom.py +++ b/module/plugins/hoster/RapidshareCom.py @@ -212,6 +212,10 @@ class RapidshareCom(Hoster): self.setWait(60) self.log.info(_("Already downloading from this ip address, waiting 60 seconds")) self.wait() + elif "Too many users downloading from this server right now" in result: + self.setWait(120) + self.log.info(_("RapidShareCom: No free slots")) + self.wait() elif between_wait: self.setWait(int(between_wait.group(1))) self.wantReconnect = True diff --git a/module/web/pyload/views.py b/module/web/pyload/views.py index a69e7da86..cfcd43061 100644 --- a/module/web/pyload/views.py +++ b/module/web/pyload/views.py @@ -28,7 +28,7 @@ def formatSize(size): """formats size of bytes""" size = int(size) steps = 0 - sizes = ["B", "KB", "MB", "GB", "TB"] + sizes = ["KB", "MB", "GB", "TB"] while size > 1000: size /= 1024.0 |