diff options
Diffstat (limited to 'module/plugins/accounts')
| -rw-r--r-- | module/plugins/accounts/FilefactoryCom.py | 57 | ||||
| -rw-r--r-- | module/plugins/accounts/FshareVn.py | 10 | 
2 files changed, 35 insertions, 32 deletions
| diff --git a/module/plugins/accounts/FilefactoryCom.py b/module/plugins/accounts/FilefactoryCom.py index 679409058..04ba0ea86 100644 --- a/module/plugins/accounts/FilefactoryCom.py +++ b/module/plugins/accounts/FilefactoryCom.py @@ -1,45 +1,46 @@  # -*- 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 -""" +############################################################################ +# This program is free software: you can redistribute it and/or modify     # +# it under the terms of the GNU Affero 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 Affero General Public License for more details.                      # +#                                                                          # +# You should have received a copy of the GNU Affero General Public License # +# along with this program.  If not, see <http://www.gnu.org/licenses/>.    # +############################################################################  import re  from time import mktime, strptime +from pycurl import REFERER +  from module.plugins.Account import Account  class FilefactoryCom(Account):      __name__ = "FilefactoryCom" -    __version__ = "0.13" +    __version__ = "0.14"      __type__ = "account"      __description__ = """filefactory.com account plugin"""      __author_name__ = ("zoidberg", "stickell")      __author_mail__ = ("zoidberg@mujmail.cz", "l.stickell@yahoo.it") -    ACCOUNT_INFO_PATTERN = r'<time datetime="([\d-]+)">' +    VALID_UNTIL_PATTERN = r'Premium valid until: <strong>(?P<d>\d{1,2})\w{1,2} (?P<m>\w{3}), (?P<y>\d{4})</strong>'      def loadAccountInfo(self, user, req): -        html = req.load("http://www.filefactory.com/member/") +        html = req.load("http://www.filefactory.com/account/") -        found = re.search(self.ACCOUNT_INFO_PATTERN, html) -        if found: +        m = re.search(self.VALID_UNTIL_PATTERN, html) +        if m:              premium = True -            validuntil = mktime(strptime(found.group(1), "%Y-%m-%d")) +            validuntil = re.sub(self.VALID_UNTIL_PATTERN, '\g<d> \g<m> \g<y>', m.group(0)) +            validuntil = mktime(strptime(validuntil, "%d %b %Y"))          else:              premium = False              validuntil = -1 @@ -47,10 +48,12 @@ class FilefactoryCom(Account):          return {"premium": premium, "trafficleft": -1, "validuntil": validuntil}      def login(self, user, data, req): -        html = req.load("http://www.filefactory.com/member/login.php", post={ -            "email": user, -            "password": data["password"], -            "redirect": "/"}) +        req.http.c.setopt(REFERER, "http://www.filefactory.com/member/login.php") + +        html = req.load("http://www.filefactory.com/member/signin.php", post={ +            "loginEmail": user, +            "loginPassword": data["password"], +            "Submit": "Sign In"}) -        if '/member/login.php?err=1' in req.http.header: +        if req.lastEffectiveURL != "http://www.filefactory.com/account/":              self.wrongPassword() diff --git a/module/plugins/accounts/FshareVn.py b/module/plugins/accounts/FshareVn.py index 75191e74a..11abfa463 100644 --- a/module/plugins/accounts/FshareVn.py +++ b/module/plugins/accounts/FshareVn.py @@ -26,13 +26,13 @@ from module.plugins.Account import Account  class FshareVn(Account):      __name__ = "FshareVn" -    __version__ = "0.04" +    __version__ = "0.05"      __type__ = "account"      __description__ = """fshare.vn account plugin""" -    __author_name__ = ("zoidberg") -    __author_mail__ = ("zoidberg@mujmail.cz") +    __author_name__ = ("zoidberg", "stickell") +    __author_mail__ = ("zoidberg@mujmail.cz", "l.stickell@yahoo.it") -    VALID_UNTIL_PATTERN = ur'<dt>Thời hạn dùng:</dt>\s*<dd>([^<]+)</dd>' +    VALID_UNTIL_PATTERN = ur'<dt>Lần đăng nhập trước:</dt>\s*<dd>([^<]+)</dd>'      TRAFFIC_LEFT_PATTERN = ur'<dt>Tổng Dung Lượng Tài Khoản</dt>\s*<dd[^>]*>([0-9.]+) ([kKMG])B</dd>'      DIRECT_DOWNLOAD_PATTERN = ur'<input type="checkbox"\s*([^=>]*)[^>]*/>Kích hoạt download trực tiếp</dt>' @@ -41,7 +41,7 @@ class FshareVn(Account):          found = re.search(self.VALID_UNTIL_PATTERN, html)          if found:              premium = True -            validuntil = mktime(strptime(found.group(1), '%I:%M:%S %p %d-%m-%Y')) +            validuntil = mktime(strptime(found.group(1), '%d-%m-%Y'))              found = re.search(self.TRAFFIC_LEFT_PATTERN, html)              trafficleft = float(found.group(1)) * 1024 ** {                  'k': 0, 'K': 0, 'M': 1, 'G': 2}[found.group(2)] if found else 0 | 
