diff options
| author | 2011-12-02 15:06:51 +0100 | |
|---|---|---|
| committer | 2011-12-02 15:06:51 +0100 | |
| commit | 9264524775c766a5d91da586cfb435da989a0629 (patch) | |
| tree | 0f4c1a799de235118eb891b3aca97bfbe67bf14f | |
| parent | update ul.to (diff) | |
| download | pyload-9264524775c766a5d91da586cfb435da989a0629.tar.xz | |
closed #440
| -rw-r--r-- | module/Utils.py | 44 | ||||
| -rw-r--r-- | module/plugins/hoster/BasePlugin.py | 4 | ||||
| -rw-r--r-- | module/plugins/hoster/UploadedTo.py | 18 | ||||
| -rw-r--r-- | module/plugins/internal/MultiHoster.py | 4 | 
4 files changed, 42 insertions, 28 deletions
| diff --git a/module/Utils.py b/module/Utils.py index 3919b5ff0..955d14b27 100644 --- a/module/Utils.py +++ b/module/Utils.py @@ -25,7 +25,7 @@ def decode(string):          return string -def removeChars(string, repl): +def remove_chars(string, repl):      """ removes all chars in repl from string"""      if type(string) == str:          return string.translate(maketrans("", ""), repl) @@ -35,9 +35,9 @@ def removeChars(string, repl):  def save_path(name):      #remove some chars      if os.name == 'nt': -        return removeChars(name, '/\\?%*:|"<>') +        return remove_chars(name, '/\\?%*:|"<>')      else: -        return removeChars(name, '/\\"') +        return remove_chars(name, '/\\"')  def save_join(*args):      """ joins a path, encoding aware """ @@ -134,21 +134,31 @@ def uniqify(seq, idfun=None):      return result -def parseFileSize(string): #returns bytes -    m = re.match(r"(\d*[\.,]?\d+)(.*)", string.strip().lower()) -    if m: -        traffic = float(m.group(1).replace(",", ".")) -        unit = m.group(2).strip() -        if unit in ("gb", "gig", "gbyte", "gigabyte", "gib"): -            traffic *= 1 << 30 -        elif unit in ("mb", "mbyte", "megabyte", "mib"): -            traffic *= 1 << 20 -        elif unit in ("kb", "kib", "kilobyte", "kbyte"): -            traffic *= 1 << 10 -        return traffic +def parseFileSize(string, unit=None): #returns bytes +    if not unit: +        m = re.match(r"(\d*[\.,]?\d+)(.*)", string.strip().lower()) +        if m: +            traffic = float(m.group(1).replace(",", ".")) +            unit = m.group(2) +        else: +            return 0 +    else: +        if isinstance(string, basestring): +            traffic = float(string.replace(",", ".")) +        else: +            traffic = string + +    #ignore case +    unit = unit.lower().strip() -    return 0 +    if unit in ("gb", "gig", "gbyte", "gigabyte", "gib", "g"): +        traffic *= 1 << 30 +    elif unit in ("mb", "mbyte", "megabyte", "mib", "m"): +        traffic *= 1 << 20 +    elif unit in ("kb", "kib", "kilobyte", "kbyte", "k"): +        traffic *= 1 << 10 +    return traffic  def lock(func):      def new(*args): @@ -190,4 +200,4 @@ def html_unescape(text):  if __name__ == "__main__":      print freeSpace(".") -    print removeChars("ab'cdgdsf''ds'", "'ghd") +    print remove_chars("ab'cdgdsf''ds'", "'ghd") diff --git a/module/plugins/hoster/BasePlugin.py b/module/plugins/hoster/BasePlugin.py index 15e35ce24..2de47940d 100644 --- a/module/plugins/hoster/BasePlugin.py +++ b/module/plugins/hoster/BasePlugin.py @@ -6,7 +6,7 @@ from urllib import unquote  from module.network.HTTPRequest import BadHeader  from module.plugins.Hoster import Hoster -from module.utils import html_unescape, removeChars +from module.utils import html_unescape, remove_chars  class BasePlugin(Hoster):      __name__ = "BasePlugin" @@ -80,7 +80,7 @@ class BasePlugin(Hoster):                  disp = m.groupdict()                  self.logDebug(disp)                  if not disp['enc']: disp['enc'] = 'utf-8' -                name = removeChars(disp['name'], "\"';").strip() +                name = remove_chars(disp['name'], "\"';").strip()                  name = unicode(unquote(name), disp['enc'])          if not name: name = url diff --git a/module/plugins/hoster/UploadedTo.py b/module/plugins/hoster/UploadedTo.py index 7ef39bf57..174c386a8 100644 --- a/module/plugins/hoster/UploadedTo.py +++ b/module/plugins/hoster/UploadedTo.py @@ -2,14 +2,13 @@  import re -from module.utils import decode, html_unescape +from module.utils import html_unescape, parseFileSize  from module.plugins.Hoster import Hoster  from module.network.RequestFactory import getURL  from module.plugins.Plugin import chunks  from module.plugins.ReCaptcha import ReCaptcha -#key = reduce(lambda x,y: x+chr(y), [(i+2)^ord(x) for i,x in enumerate("jS1\\50}eSm~5i\\cB+$XVB s^/\\mm&JUF")], "")  key = "bGhGMkllZXByd2VEZnU5Y2NXbHhYVlZ5cEE1bkEzRUw=".decode('base64')  def correctDownloadLink(url): @@ -41,7 +40,7 @@ def getAPIData(urls):          result = {} -        if len(api): +        if api:              for line in api.splitlines():                  data = line.split(",")                  if data[1] in idMap: @@ -60,7 +59,7 @@ def parseFileInfo(self, url = '', html = ''):          found = re.search(self.FILE_INFO_PATTERN, html)          if found:              name, fileid = html_unescape(found.group('N')), found.group('ID') -            size = float(found.group('S').replace(',','.')) * 1024 ** {'K':1,'M':2,'G':3}[found.group('U')] +            size = parseFileSize(found.group('S'), found.group('U'))              status = 2      return name, size, status, fileid @@ -114,18 +113,23 @@ class UploadedTo(Hoster):          api = getAPIData([pyfile.url]) -        if not len(api): +        # TODO: fallback to parse from site, because api sometimes delivers wrong status codes + +        if not api:              self.logWarning("No response for API call")              self.html = unicode(self.load(pyfile.url, decode = False), 'iso-8859-1')              name, size, status, self.fileID = parseFileInfo(self)              self.logDebug(name, size, status, self.fileID)              if status == 1: -                self.offline +                self.offline()              elif status == 2:                  pyfile.name, pyfile.size = name, size              else:                  self.fail('Parse error - file info') +        elif api == 'Access denied': +            self.fail(_("API key invalid")) +          else:              if self.fileID not in api:                  self.offline() @@ -138,7 +142,7 @@ class UploadedTo(Hoster):          # self.pyfile.name = self.get_file_name() -        if self.account and self.premium: +        if self.premium:              self.handlePremium()          else:              self.handleFree() diff --git a/module/plugins/internal/MultiHoster.py b/module/plugins/internal/MultiHoster.py index 6f0b4b636..d50df3943 100644 --- a/module/plugins/internal/MultiHoster.py +++ b/module/plugins/internal/MultiHoster.py @@ -3,7 +3,7 @@  import re -from module.utils import removeChars +from module.utils import remove_chars  from module.plugins.Hook import Hook  class MultiHoster(Hook): @@ -49,7 +49,7 @@ class MultiHoster(Hook):          new_supported = []          for hoster in self.getHosterCached(): -            name = removeChars(hoster.lower(), "-.") +            name = remove_chars(hoster.lower(), "-.")              if name in pluginMap:                  self.supported.append(pluginMap[name]) | 
