diff options
| author | 2010-09-27 12:26:41 +0200 | |
|---|---|---|
| committer | 2010-09-27 12:26:41 +0200 | |
| commit | 185a7447a8fa08a2bea704376e61e70379e529cd (patch) | |
| tree | f8480bf0735c8b1703bd1bd0a31b813e86058c1d | |
| parent | display correct file size when starting (diff) | |
| download | pyload-185a7447a8fa08a2bea704376e61e70379e529cd.tar.xz | |
ignore useless netload api results
| -rw-r--r-- | module/plugins/Plugin.py | 7 | ||||
| -rw-r--r-- | module/plugins/hoster/NetloadIn.py | 72 | 
2 files changed, 47 insertions, 32 deletions
| diff --git a/module/plugins/Plugin.py b/module/plugins/Plugin.py index 27e54cdc2..ba65370c5 100644 --- a/module/plugins/Plugin.py +++ b/module/plugins/Plugin.py @@ -212,6 +212,8 @@ class Plugin(object):          temp.write(content)          temp.close() + +        has_plugin = self.core.pluginManager.captchaPlugins.has_key(self.__name__)          if self.core.captcha:              Ocr = self.core.pluginManager.getCaptchaPlugin(self.__name__) @@ -234,7 +236,10 @@ class Plugin(object):                  if not self.core.isClientConnected():                      task.removeTask()                      #temp.unlink(temp.name) -                    self.fail(_("No Client connected for captcha decrypting, or pil and tesseract not installed")) +                    if has_plugin: +                        self.fail(_("Pil and tesseract not installed and no Client connected for captcha decrypting")) +                    else: +                        self.fail(_("No Client connected for captcha decrypting"))                  if self.pyfile.abort:                      task.removeTask()                      raise Abort diff --git a/module/plugins/hoster/NetloadIn.py b/module/plugins/hoster/NetloadIn.py index a8f96aaa3..2a1053fae 100644 --- a/module/plugins/hoster/NetloadIn.py +++ b/module/plugins/hoster/NetloadIn.py @@ -55,7 +55,7 @@ class NetloadIn(Hoster):      __name__ = "NetloadIn"      __type__ = "hoster"      __pattern__ = r"http://.*netload\.in/(?:datei(.*?)(?:\.htm|/)|index.php?id=10&file_id=)" -    __version__ = "0.2" +    __version__ = "0.3"      __description__ = """Netload.in Download Hoster"""      __config__ = [ ("dumpgen", "bool", "Generate debug page dumps on stdout", "False") ]      __author_name__ = ("spoob", "RaNaN", "Gregy") @@ -93,50 +93,60 @@ class NetloadIn(Hoster):          url = self.url          id_regex = re.compile("http://.*netload\.in/(?:datei(.*?)(?:\.htm|/)|index.php?id=10&file_id=)")          match = id_regex.search(url) -        if match: -            apiurl = "http://netload.in/share/fileinfos2.php" -            src = self.load(apiurl, cookies=False, get={"file_id": match.group(1)}).strip() -            if not src and n <= 3: -                sleep(0.2) -                self.download_api_data(n+1) -                return -            elif not src: -                self.fail(_("No API Data was send")) - -            self.log.debug("Netload: APIDATA: "+src) -            self.api_data = {} -            if src == "unknown_server_data": -                self.api_data = False -            elif src != "unknown file_data": -                lines = src.split(";") -                self.api_data["exists"] = True -                self.api_data["fileid"] = lines[0] -                self.api_data["filename"] = lines[1] -                self.api_data["size"] = lines[2] #@TODO formatting? (ex: '2.07 KB') -                self.api_data["status"] = lines[3] -                if self.api_data["status"] == "online": -                    self.api_data["checksum"] = lines[4].strip() -                else: -                    self.offline() + +        if not match: +            self.api_data = False +            return + +        apiurl = "http://netload.in/share/fileinfos2.php" +        src = self.load(apiurl, cookies=False, get={"file_id": match.group(1)}).strip() +        if not src and n <= 3: +            sleep(0.2) +            self.download_api_data(n+1) +            return  + +        self.log.debug("Netload: APIDATA: "+src) +        self.api_data = {} +        if src and src != "unknown file_data": +            lines = src.split(";") +            self.api_data["exists"] = True +            self.api_data["fileid"] = lines[0] +            self.api_data["filename"] = lines[1] +            self.api_data["size"] = lines[2] +            self.api_data["status"] = lines[3] +            if self.api_data["status"] == "online": +                self.api_data["checksum"] = lines[4].strip()              else: -                self.api_data["exists"] = False +                self.api_data = False  #check manually since api data is useless sometimes + +            if lines[0] == lines[1] and lines[2] == "0": #useless api data +                self.api_data = False          else:              self.api_data = False -            self.html = [self.load(self.url, cookies=False)] - +                  def final_wait(self, page):          wait_time = self.get_wait_time(page)          self.setWait(wait_time) -        self.log.debug(_("Netload: final wait %d seconds" % wait_time)) +        self.log.debug("Netload: final wait %d seconds" % wait_time)          self.wait()          self.url = self.get_file_url(page)      def download_html(self):          self.log.debug("Netload: Entering download_html")          page = self.load(self.url, cookies=True) + +        if not self.api_data: +            self.log.debug("API Data may be useless, get details from html page") + +            if "* The file was deleted" in page: +                self.offline() + +            name = re.search(r'class="dl_first_filename">([^<]+)', page, re.MULTILINE) +            self.pyfile.name = name.group(1).strip() +          captchawaited = False          for i in range(10): -            self.log.debug(_("Netload: try number %d " % i)) +            self.log.debug("Netload: try number %d " % i)              if self.getConf('dumpgen'):                  print page | 
