diff options
author | Walter Purcaro <vuolter@users.noreply.github.com> | 2015-07-31 03:18:42 +0200 |
---|---|---|
committer | Walter Purcaro <vuolter@users.noreply.github.com> | 2015-07-31 03:18:42 +0200 |
commit | 1b890dd55ff49ca7d6282f6e92f2fb483fb07eea (patch) | |
tree | dcc305224d358fc6b3598c1fc562c5775a976d5b /module/plugins/accounts/ShareonlineBiz.py | |
parent | [Addon] Fix unload method not called on exit (diff) | |
download | pyload-1b890dd55ff49ca7d6282f6e92f2fb483fb07eea.tar.xz |
[ShareonlineBiz] Improve account
Diffstat (limited to 'module/plugins/accounts/ShareonlineBiz.py')
-rw-r--r-- | module/plugins/accounts/ShareonlineBiz.py | 63 |
1 files changed, 35 insertions, 28 deletions
diff --git a/module/plugins/accounts/ShareonlineBiz.py b/module/plugins/accounts/ShareonlineBiz.py index 1945b2743..d7a3c8ed2 100644 --- a/module/plugins/accounts/ShareonlineBiz.py +++ b/module/plugins/accounts/ShareonlineBiz.py @@ -8,7 +8,7 @@ from module.plugins.internal.Account import Account class ShareonlineBiz(Account): __name__ = "ShareonlineBiz" __type__ = "account" - __version__ = "0.35" + __version__ = "0.36" __status__ = "testing" __description__ = """Share-online.biz account plugin""" @@ -17,40 +17,45 @@ class ShareonlineBiz(Account): def api_response(self, user, password, req): - return self.load("http://api.share-online.biz/cgi-bin", - get={'q' : "userdetails", - 'aux' : "traffic", - 'username': user, - 'password': password}) + res = self.load("http://api.share-online.biz/cgi-bin", + get={'q' : "userdetails", + 'aux' : "traffic", + 'username': user, + 'password': password}) - - def parse_info(self, user, password, data, req): - premium = False - validuntil = None - trafficleft = -1 - maxtraffic = 100 * 1024 * 1024 * 1024 #: 100 GB + self.log_debug(res) api = {} - for line in self.api_response(user, password, req).splitlines(): + for line in res.splitlines(): if "=" in line: key, value = line.split("=") api[key] = value - self.log_debug(api) + if not api['a']: + self.login_fail(_("Invalid username/password")) - if api['a'].lower() != "not_available": - req.cj.setCookie("share-online.biz", 'a', api['a']) + if api['a'].lower() == "not_available": + self.login_fail(_("No info available")) + + return api - premium = api['group'] in ("PrePaid", "Premium", "Penalty-Premium") - validuntil = float(api['expire_date']) + def parse_info(self, user, password, data, req): + premium = False + validuntil = None + trafficleft = -1 + maxtraffic = 100 * 1024 * 1024 * 1024 #: 100 GB + + api = self.api_response(user, password, req) - traffic = float(api['traffic_1d'].split(";")[0]) + premium = api['group'] in ("PrePaid", "Premium", "Penalty-Premium") + validuntil = float(api['expire_date']) + traffic = float(api['traffic_1d'].split(";")[0]) - if maxtraffic > traffic: - trafficleft = maxtraffic - traffic - else: - trafficleft = -1 + if maxtraffic > traffic: + trafficleft = maxtraffic - traffic + else: + trafficleft = -1 maxtraffic /= 1024 #@TODO: Remove `/ 1024` in 0.4.10 trafficleft /= 1024 #@TODO: Remove `/ 1024` in 0.4.10 @@ -62,8 +67,10 @@ class ShareonlineBiz(Account): def login(self, user, password, data, req): - html = self.api_response(user, password, req) - err = re.search(r'\*\*(.+?)\*\*', html) - if err: - self.log_error(err.group(1).strip()) - self.login_fail() + api = self.api_response(user, password, req) + err = re.search(r'\*\*(.+?)\*\*', api) + + if not err: + req.cj.setCookie("share-online.biz", 'a', api['a']) + else: + self.login_fail(err.group(1)) |