diff options
| author | 2013-12-04 12:03:04 +0100 | |
|---|---|---|
| committer | 2013-12-04 12:03:04 +0100 | |
| commit | b140dd072550d78ae8deffbdd86ac7c2696eab8d (patch) | |
| tree | fdd99e65aa4ce3338ea8c9aac9d56d21a55d188c /module/plugins | |
| parent | NowDownloadEu: fixed syntax error (diff) | |
| parent | Ulozto changed captcha code (diff) | |
| download | pyload-b140dd072550d78ae8deffbdd86ac7c2696eab8d.tar.xz | |
Merge pull request #427 from kmarty/stable
Ulozto: changed captcha code
Diffstat (limited to 'module/plugins')
| -rw-r--r-- | module/plugins/hoster/UlozTo.py | 53 | 
1 files changed, 29 insertions, 24 deletions
| diff --git a/module/plugins/hoster/UlozTo.py b/module/plugins/hoster/UlozTo.py index fe0bc671e..5f5d44b01 100644 --- a/module/plugins/hoster/UlozTo.py +++ b/module/plugins/hoster/UlozTo.py @@ -17,19 +17,19 @@  """  import re +import time  from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo - +from module.common.json_layer import json_loads  def convertDecimalPrefix(m):      # decimal prefixes used in filesize and traffic      return ("%%.%df" % {'k': 3, 'M': 6, 'G': 9}[m.group(2)] % float(m.group(1))).replace('.', '') -  class UlozTo(SimpleHoster):      __name__ = "UlozTo"      __type__ = "hoster"      __pattern__ = r"http://(\w*\.)?(uloz\.to|ulozto\.(cz|sk|net)|bagruj.cz|zachowajto.pl)/(?:live/)?(?P<id>\w+/[^/?]*)" -    __version__ = "0.93" +    __version__ = "0.94"      __description__ = """uloz.to"""      __author_name__ = ("zoidberg") @@ -80,36 +80,41 @@ class UlozTo(SimpleHoster):          if not action or not inputs:              self.parseError("free download form") -        # get and decrypt captcha -        captcha_id_field = captcha_text_field = None - +        # I don't know how to check captcha form changes          for key in inputs.keys(): -            found = re.match("captcha.*(id|text|value)", key) +            found = re.match("(captcha_value|timestamp|salt|hash)", key)              if found: -                if found.group(1) == "id": -                    captcha_id_field = key -                else: -                    captcha_text_field = key - -        if not captcha_id_field or not captcha_text_field: -            self.parseError("CAPTCHA form changed") +                if found.group(1) == "captcha_value": +                    junk_captcha_value = key +                elif found.group(1) == "timestamp": +                    junk_timestamp = key +                elif found.group(1) == "salt": +                    junk_salt = key +                elif found.group(1) == "hash": +                    junk_hash = key + +        if not junk_captcha_value or not junk_timestamp or not junk_salt or not junk_hash: +            self.parseError("CAPTCHA form changed")     -        # captcha_id = self.getStorage("captcha_id") -        # captcha_text = self.getStorage("captcha_text") -        # -        # if not captcha_id or not captcha_text: +        # get and decrypt captcha +        my_timestamp = int(time.time()) +        self.logDebug('my_timestamp = ' + str(my_timestamp)) -        captcha_id = inputs[captcha_id_field] -        captcha_text = self.decryptCaptcha("http://img.uloz.to/captcha/%s.png" % captcha_id) +        xapca = self.load("http://www.ulozto.net/reloadXapca.php", get = { "rnd": str(my_timestamp)}) +        self.logDebug('xapca = ' + str(xapca)) -        self.logDebug(' CAPTCHA ID:' + captcha_id + ' CAPTCHA TEXT:' + captcha_text) +        data = json_loads(xapca) +        self.logDebug('image = ' + str(data["image"])) +        self.logDebug('sound = ' + str(data["sound"])) +        self.logDebug('timestamp = ' + str(data["timestamp"])) +        self.logDebug('salt = ' + str(data["salt"])) +        self.logDebug('hash = ' + str(data["hash"])) -        # self.setStorage("captcha_id", captcha_id) -        # self.setStorage("captcha_text", captcha_text) +        captcha_text = self.decryptCaptcha(str(data["image"]))          self.multiDL = True -        inputs.update({captcha_id_field: captcha_id, captcha_text_field: captcha_text}) +        inputs.update({"timestamp": data["timestamp"], "salt": data["salt"], "hash": data["hash"], "captcha_value": captcha_text})          self.download("http://www.ulozto.net" + action, post=inputs, cookies=True, disposition=True) | 
