# -*- 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 . @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'
]*action="([^"]+user_hash=([^"]+))">' CREDIT_LEFT_PATTERN = r'(\d+)' WRONG_PASSWORD_PATTERN = r'

\s*Wrong user or password was entered
' 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()