diff options
| author | 2012-01-29 12:32:12 +0100 | |
|---|---|---|
| committer | 2012-01-29 12:32:12 +0100 | |
| commit | 8edf00933b4d7731bffc77c32faccffcf9d038fb (patch) | |
| tree | ff13fed1319cf39a6daaaa2156703e0c37a1ff3e /module/plugins/internal | |
| parent | Update version. (diff) | |
| parent | increase version (diff) | |
| download | pyload-8edf00933b4d7731bffc77c32faccffcf9d038fb.tar.xz | |
merge from stable
Diffstat (limited to 'module/plugins/internal')
| -rw-r--r-- | module/plugins/internal/DeadHoster.py | 18 | ||||
| -rw-r--r-- | module/plugins/internal/SimpleHoster.py | 21 | 
2 files changed, 34 insertions, 5 deletions
| diff --git a/module/plugins/internal/DeadHoster.py b/module/plugins/internal/DeadHoster.py new file mode 100644 index 000000000..e180e2384 --- /dev/null +++ b/module/plugins/internal/DeadHoster.py @@ -0,0 +1,18 @@ +from module.plugins.Hoster import Hoster as _Hoster + +def create_getInfo(plugin): +    def getInfo(urls): +        yield [('#N/A: ' + url, 0, 1, url) for url in urls] +    return getInfo + +class DeadHoster(_Hoster): +    __name__ = "DeadHoster" +    __type__ = "hoster" +    __pattern__ = r"" +    __version__ = "0.11" +    __description__ = """Hoster is no longer available""" +    __author_name__ = ("zoidberg") +    __author_mail__ = ("zoidberg@mujmail.cz") +     +    def setup(self): +        self.fail("Hoster is no longer available")
\ No newline at end of file diff --git a/module/plugins/internal/SimpleHoster.py b/module/plugins/internal/SimpleHoster.py index 12b629a81..69909a8a1 100644 --- a/module/plugins/internal/SimpleHoster.py +++ b/module/plugins/internal/SimpleHoster.py @@ -18,6 +18,7 @@  """  from urlparse import urlparse  import re +from time import time  from module.plugins.Hoster import Hoster  from module.utils import html_unescape, fixup, parseFileSize @@ -36,10 +37,13 @@ def parseHtmlTagAttrValue(attr_name, tag):  def parseFileInfo(self, url = '', html = '', infomode = False):      if not html and hasattr(self, "html"): html = self.html +          info = {"name" : url, "size" : 0, "status" : 3}      online = False -    if hasattr(self, "FILE_OFFLINE_PATTERN") and re.search(self.FILE_OFFLINE_PATTERN, html): +    if hasattr(self, "req") and self.req.http.code == '404': +        info['status'] = 1 +    elif hasattr(self, "FILE_OFFLINE_PATTERN") and re.search(self.FILE_OFFLINE_PATTERN, html):          # File offline          info['status'] = 1      else: @@ -53,7 +57,8 @@ def parseFileInfo(self, url = '', html = '', infomode = False):          if online:              # File online, return name and size              info['status'] = 2 -            if 'N' in info: info['name'] = reSub(info['N'], self.FILE_NAME_REPLACEMENTS) +            if 'N' in info:  +                info['name'] = reSub(info['N'], self.FILE_NAME_REPLACEMENTS)              if 'S' in info:                  size = reSub(info['S'] + info['U'] if 'U' in info else info['S'], self.FILE_SIZE_REPLACEMENTS)                  info['size'] = parseFileSize(size) @@ -69,10 +74,14 @@ def parseFileInfo(self, url = '', html = '', infomode = False):  def create_getInfo(plugin):      def getInfo(urls):          for url in urls: -            file_info = parseFileInfo(plugin, url, getURL(reSub(url, plugin.FILE_URL_REPLACEMENTS), decode=True)) +            file_info = parseFileInfo(plugin, url, getURL(reSub(url, plugin.FILE_URL_REPLACEMENTS), \ +                decode = False if plugin.HTML_BROKEN_ENCODING else True))              yield file_info      return getInfo +def timestamp(): +    return int(time()*1000) +  class PluginParseError(Exception):      def __init__(self, msg):          Exception.__init__(self) @@ -82,7 +91,7 @@ class PluginParseError(Exception):  class SimpleHoster(Hoster):      __name__ = "SimpleHoster" -    __version__ = "0.16" +    __version__ = "0.17"      __pattern__ = None      __type__ = "hoster"      __description__ = """Base hoster plugin""" @@ -100,13 +109,15 @@ class SimpleHoster(Hoster):      FILE_SIZE_REPLACEMENTS = []      FILE_NAME_REPLACEMENTS = [("&#?\w+;", fixup)]      FILE_URL_REPLACEMENTS = [] +     +    HTML_BROKEN_ENCODING = False      def setup(self):          self.resumeDownload = self.multiDL = True if self.account else False      def process(self, pyfile):          pyfile.url = reSub(pyfile.url, self.FILE_URL_REPLACEMENTS) -        self.html = self.load(pyfile.url, decode = True) +        self.html = self.load(pyfile.url, decode = False if self.HTML_BROKEN_ENCODING else True)          self.file_info = self.getFileInfo()          if self.premium:              self.handlePremium() | 
