diff options
Diffstat (limited to 'module/plugins/accounts')
| -rw-r--r-- | module/plugins/accounts/HellspyCz.py | 82 | 
1 files changed, 82 insertions, 0 deletions
| diff --git a/module/plugins/accounts/HellspyCz.py b/module/plugins/accounts/HellspyCz.py new file mode 100644 index 000000000..10c7e3882 --- /dev/null +++ b/module/plugins/accounts/HellspyCz.py @@ -0,0 +1,82 @@ +# -*- 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: zoidberg +""" + +from module.plugins.Account import Account +import re +import string + +class HellspyCz(Account): +    __name__ = "HellspyCz" +    __version__ = "0.2" +    __type__ = "account" +    __description__ = """hellspy.cz account plugin""" +    __author_name__ = ("zoidberg") +    __author_mail__ = ("zoidberg@mujmail.cz") +     +    ACTION_PATTERN = r'<div id="snippet--loginBoxSn"><form[^>]*action="([^"]+user_hash=([^"]+))">' +    CREDIT_LEFT_PATTERN = r'<strong class="text-credits">(\d+)</strong>' +    WRONG_PASSWORD_PATTERN = r'<p class="block-error-3 marg-tb-050">\s*Wrong user or password was entered<br />' + +    phpsessid = ''  + +    def loadAccountInfo(self, user, req): +        cj = self.getAccountCookies(user) +        cj.setCookie(".hellspy.com", "PHPSESSID", self.phpsessid)        +     +        html = req.load("http://www.hellspy.com/") +         +        found = re.search(self.CREDIT_LEFT_PATTERN, html) +        if found is None: +            credits = 0 +        else: +            credits = int(found.group(1)) * 1024 +         +        return {"validuntil": -1, "trafficleft": credits} +     +    def login(self, user, data,req):         +        html = req.load('http://www.hellspy.com/') +        found = re.search(self.ACTION_PATTERN, html) +        if found is None: +           self.logError('Parse error (FORM)')  +        action, self.phpsessid = found.group(1).replace('&','&'), found.group(2) +         +        self.logDebug("PHPSESSID:" + self.phpsessid) +        html = req.load("http://www.hellspy.com/--%s-" % self.phpsessid) +         +        html = req.load(action, post={ +                "login": "1", +                "password": data["password"], +                "username": user, +                "redir_url":	'http://www.hellspy.com/?do=loginBox-login', +                "permanent_login": "1" +                })                      +         +        cj = self.getAccountCookies(user) +        cj.setCookie(".hellspy.com", "PHPSESSID", self.phpsessid) +                         +        self.logDebug(req.lastURL) +        self.logDebug(req.lastEffectiveURL) +         +        html = req.load("http://www.hellspy.com/", get = {"do":"loginBox-login"}) +                 +        if not re.search(self.CREDIT_LEFT_PATTERN, html): +            self.wrongPassword() + + +            
\ No newline at end of file | 
