diff options
| author | 2011-06-02 00:17:26 +0200 | |
|---|---|---|
| committer | 2011-06-02 00:17:26 +0200 | |
| commit | 3355a922b7e7327da25c064c0639e80987f873e0 (patch) | |
| tree | 6be0f85acc69da544149f985eb1bd40d748fd33a | |
| parent | tidy up wait code (diff) | |
| download | pyload-3355a922b7e7327da25c064c0639e80987f873e0.tar.xz | |
wupload plugin (free)
| -rw-r--r-- | module/ThreadManager.py | 7 | ||||
| -rw-r--r-- | module/plugins/hoster/FilesonicCom.py | 68 | ||||
| -rw-r--r-- | module/plugins/hoster/WuploadCom.py | 89 | 
3 files changed, 129 insertions, 35 deletions
| diff --git a/module/ThreadManager.py b/module/ThreadManager.py index 82cb9a449..a8e8b2772 100644 --- a/module/ThreadManager.py +++ b/module/ThreadManager.py @@ -218,8 +218,11 @@ class ThreadManager:                  job.initPlugin()              except Exception, e:                  self.log.critical(str(e)) -                if self.core.debug: -                    print_exc() +                print_exc() +                job.setStatus("failed") +                job.error = str(e) +                job.release() +                return              if job.plugin.__type__ == "hoster":                  if free: diff --git a/module/plugins/hoster/FilesonicCom.py b/module/plugins/hoster/FilesonicCom.py index cbe3aa9d8..48f8c3849 100644 --- a/module/plugins/hoster/FilesonicCom.py +++ b/module/plugins/hoster/FilesonicCom.py @@ -18,43 +18,46 @@ except ImportError: # pragma: no cover  def getInfo(urls):
      for chunk in chunks(urls, 20):
 -        result=[]
 -        ids=dict()
 +        result = []
 +        ids = dict()
          for url in chunk:
              id = getId(url)
              if id:
 -                ids[id]=url
 +                ids[id] = url
              else:
 -                result.append((none,0,1,url))
 +                result.append((None, 0, 1, url))
          if len(ids) > 0:
 -            check_url="http://api.filesonic.com/link?method=getInfo&format=json&ids=" + ",".join(ids.keys())
 -            response = json_loads(getURL(check_url).decode("utf8","ignore"))
 +            check_url = "http://api.filesonic.com/link?method=getInfo&format=json&ids=" + ",".join(ids.keys())
 +            response = json_loads(getURL(check_url).decode("utf8", "ignore"))
              for item in response["FSApi_Link"]["getInfo"]["response"]["links"]:
                  if item["status"] != "AVAILABLE":
 -                    result.append((None,0,1,ids[item["id"]]))
 +                    result.append((None, 0, 1, ids[item["id"]]))
                  else:
 -                    result.append((item["filename"],item["size"],2,ids[str(item["id"])]))
 +                    result.append((item["filename"], item["size"], 2, ids[str(item["id"])]))
          yield result
 +
  def getId(url):
 -    match = re.search(FilesonicCom.FILE_ID_PATTERN,url)
 +    match = re.search(FilesonicCom.FILE_ID_PATTERN, url)
      if match:
 -        return string.replace(match.group("id"),"/","-")
 +        return string.replace(match.group("id"), "/", "-")
      else:
          return None
 +
  class FilesonicCom(Hoster):
      __name__ = "FilesonicCom"
      __type__ = "hoster"
      __pattern__ = r"http://[\w\.]*?(sharingmatrix|filesonic)\..*?/file/(([a-z][0-9]+/)?[0-9]+)(/.*)?"
      __version__ = "0.31"
      __description__ = """FilesonicCom und Sharingmatrix Download Hoster"""
 -    __author_name__ = ("jeix","paulking")
 -    __author_mail__ = ("jeix@hasnomail.de","")
 +    __author_name__ = ("jeix", "paulking")
 +    __author_mail__ = ("jeix@hasnomail.de", "")
 +    API_ADDRESS = "http://api.filesonic.com"
      URL_DOMAIN_PATTERN = r'(?P<prefix>.*?)(?P<domain>.(filesonic|sharingmatrix)\..+?)(?P<suffix>/.*)'
 -    FILE_ID_PATTERN = r'/file/(?P<id>([a-z][0-9]+/)?[0-9]+)(/.*)?'
 +    FILE_ID_PATTERN = r'/file/(?P<id>([a-z][0-9]+/)?[0-9]+)(/.*)?' #change may break wupload - be careful
      FILE_LINK_PATTERN = r'<p><a href="(http://.+?\.(filesonic|sharingmatrix)\..+?)"><span>Start download'
      WAIT_TIME_PATTERN = r'countDownDelay = (?P<wait>\d+)'
      WAIT_TM_PATTERN = r"name='tm' value='(.*?)' />"
 @@ -70,7 +73,6 @@ class FilesonicCom(Hoster):              self.multiDL = False
      def process(self, pyfile):
 -
          self.pyfile = pyfile
          self.pyfile.url = self.checkFile(self.pyfile.url)
 @@ -80,15 +82,15 @@ class FilesonicCom(Hoster):          else:
              self.downloadFree()
 -    def checkFile(self,url):
 +    def checkFile(self, url):
          id = getId(url)
 -        self.log.debug("%s: file id is %s" % (self.__name__,id))
 +        self.log.debug("%s: file id is %s" % (self.__name__, id))
          if id:
              # Use the api to check the current status of the file and fixup data
 -            check_url="http://api.filesonic.com/link?method=getInfo&format=json&ids=%s" % id
 -            result = json_loads(self.load(check_url).decode("utf8","ignore"))
 +            check_url = self.API_ADDRESS + "/link?method=getInfo&format=json&ids=%s" % id
 +            result = json_loads(self.load(check_url).decode("utf8", "ignore"))
              item = result["FSApi_Link"]["getInfo"]["response"]["links"][0]
 -            self.log.debug("%s: api check returns %s" % (self.__name__,item))
 +            self.log.debug("%s: api check returns %s" % (self.__name__, item))
              if item["status"] != "AVAILABLE":
                  self.offline()
 @@ -99,21 +101,22 @@ class FilesonicCom(Hoster):              #if item["is_premium_only"] != 0 and not self.premium:
              #    self.fail("need premium account for file")
 -            self.pyfile.name=item["filename"]
 +            self.pyfile.name = item["filename"]
              # Fix the url and resolve the domain to the correct regional variation
 -            url=item["url"]
 -            urlparts = re.search(self.URL_DOMAIN_PATTERN,url)
 +            url = item["url"]
 +            urlparts = re.search(self.URL_DOMAIN_PATTERN, url)
              if urlparts:
 -                url = urlparts.group("prefix")+self.getDomain()+urlparts.group("suffix")
 -                self.log.debug("%s: localised url is %s" % (self.__name__,url))
 +                url = urlparts.group("prefix") + self.getDomain() + urlparts.group("suffix")
 +                self.log.debug("%s: localised url is %s" % (self.__name__, url))
              return url
          else:
              self.fail("Invalid URL")
      def getDomain(self):
 -        result = json_loads(self.load("http://api.filesonic.com/utility?method=getFilesonicDomainForCurrentIp&format=json").decode("utf8","ignore"))
 -        self.log.debug("%s: response to get domain %s" % (self.__name__,result))
 +        result = json_loads(
 +            self.load(self.API_ADDRESS + "/utility?method=getFilesonicDomainForCurrentIp&format=json", utf8=True))
 +        self.log.debug("%s: response to get domain %s" % (self.__name__, result))
          return result["FSApi_Utility"]["getFilesonicDomainForCurrentIp"]["response"]
 @@ -133,12 +136,11 @@ class FilesonicCom(Hoster):          if not finalUrl:
              self.doWait(url)
 -        
 +
              chall = re.search(self.CAPTCHA_TYPE1_PATTERN, self.html)
              chall2 = re.search(self.CAPTCHA_TYPE2_PATTERN, self.html)
              if chall or chall2:
                  for i in range(5):
 -
                      re_captcha = ReCaptcha(self)
                      if chall:
                          self.log.debug("%s: Captcha type1" % self.__name__)
 @@ -150,7 +152,7 @@ class FilesonicCom(Hoster):                          result = re_captcha.result(server, challenge)
                      postData = {"recaptcha_challenge_field": challenge,
 -                                "recaptcha_response_field" : result}
 +                                "recaptcha_response_field": result}
                      self.html = self.load(url, post=postData)
                      self.handleErrors()
 @@ -159,7 +161,7 @@ class FilesonicCom(Hoster):                      if chall or chall2:
                          self.invalidCaptcha()
 -                    else: 
 +                    else:
                          self.correctCaptcha()
                          break
 @@ -173,11 +175,11 @@ class FilesonicCom(Hoster):      def doWait(self, url):
          # If the current page requires us to wait then wait and move to the next page as required
 -        
 +
          # There maybe more than one wait period. The extended wait if download limits have been exceeded (in which case we try reconnect)
          # and the short wait before every download. Visually these are the same, the difference is that one includes a code to allow
          # progress to the next page
 -        
 +
          waitSearch = re.search(self.WAIT_TIME_PATTERN, self.html)
          while waitSearch:
              wait = int(waitSearch.group("wait"))
 @@ -194,7 +196,7 @@ class FilesonicCom(Hoster):              if tm and tm_hash:
                  tm = tm.group(1)
                  tm_hash = tm_hash.group(1)
 -                self.html = self.load(url, post={"tm":tm,"tm_hash":tm_hash})
 +                self.html = self.load(url, post={"tm": tm, "tm_hash": tm_hash})
                  self.handleErrors()
                  break
              else:
 diff --git a/module/plugins/hoster/WuploadCom.py b/module/plugins/hoster/WuploadCom.py new file mode 100644 index 000000000..e19ca1cd3 --- /dev/null +++ b/module/plugins/hoster/WuploadCom.py @@ -0,0 +1,89 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +import re +import string + +from types import MethodType + +from module.plugins.Hoster import Hoster +from module.plugins.Plugin import chunks + +from module.network.RequestFactory import getURL + +try: +    from json import loads as json_loads +except ImportError: # pragma: no cover +    from module.lib.simplejson import loads as json_loads + +def getInfo(urls): +    for chunk in chunks(urls, 20): +        result = [] +        ids = dict() +        for url in chunk: +            id = getId(url) +            if id: +                ids[id] = url +            else: +                result.append((None, 0, 1, url)) + +        if len(ids) > 0: +            check_url = "http://api.wupload.com/link?method=getInfo&format=json&ids=" + ",".join(ids.keys()) +            response = json_loads(getURL(check_url).decode("utf8", "ignore")) +            for item in response["FSApi_Link"]["getInfo"]["response"]["links"]: +                if item["status"] != "AVAILABLE": +                    result.append((None, 0, 1, ids[item["id"]])) +                else: +                    result.append((item["filename"], item["size"], 2, ids[str(item["id"])])) +        yield result + + +def getId(url): +    match = re.search(WuploadCom.FILE_ID_PATTERN, url) +    if match: +        return string.replace(match.group("id"), "/", "-") +    else: +        return None + + +class WuploadCom(Hoster): +    __name__ = "WuploadCom" +    __type__ = "hoster" +    __pattern__ = r"http://[\w\.]*?wupload\..*?/file/(([a-z][0-9]+/)?[0-9]+)(/.*)?" +    __version__ = "0.1" +    __description__ = """Wupload com""" +    __author_name__ = ("jeix", "paulking") +    __author_mail__ = ("jeix@hasnomail.de", "") + +    API_ADDRESS = "http://api.wupload.com" +    URL_DOMAIN_PATTERN = r'(?P<prefix>.*?)(?P<domain>.wupload\..+?)(?P<suffix>/.*)' +    FILE_ID_PATTERN = r'/file/(?P<id>([a-z][0-9]+/)?[0-9]+)(/.*)?' +    FILE_LINK_PATTERN = r'<p><a href="(http://.+?\.wupload\..+?)"><span>Download Now' +    WAIT_TIME_PATTERN = r'countDownDelay = (?P<wait>\d+)' +    WAIT_TM_PATTERN = r"name='tm' value='(.*?)' />" +    WAIT_TM_HASH_PATTERN = r"name='tm_hash' value='(.*?)' />" +    CAPTCHA_TYPE1_PATTERN = r'Recaptcha.create\("(.*?)",' +    CAPTCHA_TYPE2_PATTERN = r'id="recaptcha_image"><img style="display: block;" src="(.+)image?c=(.+?)"' + +    def init(self): +        #this plugin shares most things with filesonic, always keep in mind when editing it + +        module = self.core.pluginManager.getPlugin("FilesonicCom") +        fs = getattr(module, "FilesonicCom") + +        self.newInit = MethodType(fs.__dict__["init"], self, WuploadCom) + +        methods = ["process", "checkFile", "downloadPremium", "downloadFree", "doWait", "handleErrors"] +        #methods to bind from fs + +        for m in methods: +            setattr(self, m, MethodType(fs.__dict__[m], self, WuploadCom)) + +        self.newInit() + + +    def getDomain(self): +        result = json_loads( +            self.load(self.API_ADDRESS + "/utility?method=getWuploadDomainForCurrentIp&format=json", utf8=True)) +        self.log.debug("%s: response to get domain %s" % (self.__name__, result)) +        return result["FSApi_Utility"]["getWuploadDomainForCurrentIp"]["response"]
\ No newline at end of file | 
