From 56d409331faeb3c4535d11b265e901797bb9e337 Mon Sep 17 00:00:00 2001
From: zoidberg10 <zoidberg@mujmail.cz>
Date: Tue, 22 May 2012 00:20:08 +0200
Subject: add uploadhero (thx mcmyst), wrzuc.to, gigapeta.com

---
 module/plugins/accounts/FilefactoryCom.py | 28 +++++------
 module/plugins/accounts/UploadheroCom.py  | 35 ++++++++++++++
 module/plugins/hoster/GigapetaCom.py      | 73 ++++++++++++++++++++++++++++
 module/plugins/hoster/UploadheroCom.py    | 79 +++++++++++++++++++++++++++++++
 module/plugins/hoster/WrzucTo.py          | 58 +++++++++++++++++++++++
 5 files changed, 259 insertions(+), 14 deletions(-)
 create mode 100644 module/plugins/accounts/UploadheroCom.py
 create mode 100644 module/plugins/hoster/GigapetaCom.py
 create mode 100644 module/plugins/hoster/UploadheroCom.py
 create mode 100644 module/plugins/hoster/WrzucTo.py

(limited to 'module')

diff --git a/module/plugins/accounts/FilefactoryCom.py b/module/plugins/accounts/FilefactoryCom.py
index 8c04cf49b..73431b546 100644
--- a/module/plugins/accounts/FilefactoryCom.py
+++ b/module/plugins/accounts/FilefactoryCom.py
@@ -23,32 +23,32 @@ from time import mktime, strptime
 
 class FilefactoryCom(Account):
     __name__ = "FilefactoryCom"
-    __version__ = "0.1"
+    __version__ = "0.11"
     __type__ = "account"
     __description__ = """filefactory.com account plugin"""
     __author_name__ = ("zoidberg")
     __author_mail__ = ("zoidberg@mujmail.cz")
     
-    ACCOUNT_INFO_PATTERN = r'Your account is valid until the <strong>(.*?)</strong>' 
-
-    def loadAccountInfo(self, user, req):
-        premium = False
-        validuntil = -1
-        
-        html = req.load("http://filefactory.com/member/")
-        if "You are a FileFactory Premium Member" in html:
+    ACCOUNT_INFO_PATTERN = r'"greenText">Premium member until<.*?datetime="(.*?)"'
+
+    def loadAccountInfo(self, user, req):      
+        html = req.load("http://www.filefactory.com/member/")
+            
+        found = re.search(self.ACCOUNT_INFO_PATTERN, html)
+        if found:
             premium = True
-            found = re.search(self.ACCOUNT_INFO_PATTERN, html)
-            if found:
-                validuntil = mktime(strptime(re.sub(r"(\d)[a-z]{2} ", r"\1 ", found.group(1)),"%d %B, %Y")) 
+            validuntil = mktime(strptime(re.sub(r"(\d)[a-z]{2} ", r"\1 ", found.group(1)),"%d %B, %Y"))
+        else:
+            premium = False
+            validuntil = -1   
 
         return {"premium": premium, "trafficleft": -1, "validuntil": validuntil}
 
     def login(self, user, data, req):
-        html = req.load("http://filefactory.com/member/login.php", post={
+        html = req.load("http://www.filefactory.com/member/login.php", post={
             "email": user, 
             "password": data["password"],
             "redirect": "/"})
             
-        if not re.search(r'location:.*?\?login=1', req.http.header, re.I):
+        if '/member/login.php?err=1' in req.http.header:
             self.wrongPassword()
\ No newline at end of file
diff --git a/module/plugins/accounts/UploadheroCom.py b/module/plugins/accounts/UploadheroCom.py
new file mode 100644
index 000000000..f1e0649e6
--- /dev/null
+++ b/module/plugins/accounts/UploadheroCom.py
@@ -0,0 +1,35 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+
+from module.plugins.Account import Account
+import re,datetime,time
+
+class UploadheroCom(Account):
+    __name__ = "UploadheroCom"
+    __version__ = "0.1"
+    __type__ = "account"
+    __description__ = """Uploadhero.com account plugin"""
+    __author_name__ = ("mcmyst")
+    __author_mail__ = ("mcmyst@hotmail.fr")
+
+
+    def loadAccountInfo(self, user, req):
+        premium_pattern = re.compile('Il vous reste <span class="bleu">([0-9]+)</span> jours premium.')
+
+        data = self.getAccountData(user)
+        page = req.load("http://uploadhero.com/my-account")
+
+        if premium_pattern.search(page):
+                end_date = datetime.date.today() + datetime.timedelta(days=int(premium_pattern.search(page).group(1)))
+                end_date = time.mktime(future.timetuple())
+                account_info = {"validuntil": end_date, "trafficleft": -1, "premium": True}
+        else:
+                account_info = {"validuntil": -1, "trafficleft": -1, "premium": False}
+
+        return account_info
+
+    def login(self, user, data, req):
+        page = req.load("http://uploadhero.com/lib/connexion.php", post={"pseudo_login": user, "password_login": data["password"]})
+
+        if "mot de passe invalide" in page:
+            self.wrongPassword()
\ No newline at end of file
diff --git a/module/plugins/hoster/GigapetaCom.py b/module/plugins/hoster/GigapetaCom.py
new file mode 100644
index 000000000..28ba35abe
--- /dev/null
+++ b/module/plugins/hoster/GigapetaCom.py
@@ -0,0 +1,73 @@
+# -*- coding: utf-8 -*-
+"""
+    This program is free software; you can redistribute it and/or modify
+    it under the terms of the GNU General Public License as published by
+    the Free Software Foundation; either version 3 of the License,
+    or (at your option) any later version.
+
+    This program is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+    See the GNU General Public License for more details.
+
+    You should have received a copy of the GNU General Public License
+    along with this program; if not, see <http://www.gnu.org/licenses/>.
+
+    @author: zoidberg
+"""
+
+import re
+from random import randint
+from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo
+from pycurl import FOLLOWLOCATION
+
+class GigapetaCom(SimpleHoster):
+    __name__ = "GigapetaCom"
+    __type__ = "hoster"
+    __pattern__ = r"http://(?:www\.)?gigapeta\.com/dl/\w+"
+    __version__ = "0.01"
+    __description__ = """GigaPeta.com plugin - free only"""
+    __author_name__ = ("zoidberg")
+    __author_mail__ = ("zoidberg@mujmail.cz")
+
+    SH_COOKIES = [("http://gigapeta.com", "lang", "us")]
+    FILE_NAME_PATTERN = r'<img src=".*" alt="file" />-->\s*(?P<N>.*?)\s*</td>'
+    FILE_SIZE_PATTERN = r'<th>\s*Size\s*</th>\s*<td>\s*(?P<S>.*?)\s*</td>'
+    FILE_OFFLINE_PATTERN = r'<div id="page_error">'
+    
+    def handleFree(self):       
+        captcha_key = str(randint(1,100000000))
+        captcha_url = "http://gigapeta.com/img/captcha.gif?x=%s" % captcha_key
+               
+        self.req.http.c.setopt(FOLLOWLOCATION, 0)
+        
+        for i in range(5):
+            self.checkErrors()
+            
+            captcha = self.decryptCaptcha(captcha_url)    
+            self.html = self.load(self.pyfile.url, post = {
+                "captcha_key": captcha_key, 
+                "captcha": captcha,
+                "download": "Download"})
+            
+            found = re.search(r"Location\s*:\s*(.*)", self.req.http.header, re.I)
+            if found:
+                download_url = found.group(1)                
+                break          
+            elif "Entered figures don&#96;t coincide with the picture" in self.html:
+                self.invalidCaptcha()            
+        else:
+            self.fail("No valid captcha code entered")                  
+        
+        self.req.http.c.setopt(FOLLOWLOCATION, 1)
+        self.logDebug("Download URL: %s" % download_url)
+        self.download(download_url)
+             
+    def checkErrors(self):
+        if "All threads for IP" in self.html:
+            self.logDebug("Your IP is already downloading a file - wait and retry")
+            self.setWait(300, True)
+            self.wait()
+            self.retry()
+        
+getInfo = create_getInfo(GigapetaCom)
\ No newline at end of file
diff --git a/module/plugins/hoster/UploadheroCom.py b/module/plugins/hoster/UploadheroCom.py
new file mode 100644
index 000000000..dd43d76b9
--- /dev/null
+++ b/module/plugins/hoster/UploadheroCom.py
@@ -0,0 +1,79 @@
+# -*- coding: utf-8 -*-
+"""
+    This program is free software; you can redistribute it and/or modify
+    it under the terms of the GNU General Public License as published by
+    the Free Software Foundation; either version 3 of the License,
+    or (at your option) any later version.
+
+    This program is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+    See the GNU General Public License for more details.
+
+    You should have received a copy of the GNU General Public License
+    along with this program; if not, see <http://www.gnu.org/licenses/>.
+
+    @author: zoidberg
+"""
+
+import re
+from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo
+
+class UploadheroCom(SimpleHoster):
+    __name__ = "UploadheroCom"
+    __type__ = "hoster"
+    __pattern__ = r"http://(?:www\.)?uploadhero\.com/dl/\w+"
+    __version__ = "0.11"
+    __description__ = """UploadHero.com plugin"""
+    __author_name__ = ("mcmyst", "zoidberg")
+    __author_mail__ = ("mcmyst@hotmail.fr", "zoidberg@mujmail.cz")
+
+    SH_COOKIES = [("http://uploadhero.com", "lang", "en")]
+    FILE_NAME_PATTERN = r'<div class="nom_de_fichier">(?P<N>.*?)</div>'
+    FILE_SIZE_PATTERN = r'Taille du fichier : </span><strong>(?P<S>.*?)</strong>'
+    FILE_OFFLINE_PATTERN = r'<p class="titre_dl_2">|<div class="raison"><strong>Le lien du fichier ci-dessus n\'existe plus.'
+    
+    DOWNLOAD_URL_PATTERN = r'<a href="([^"]+)" id="downloadnow"'
+    
+    IP_WAIT_PATTERN = r'/lightbox_block_download\.php\?min=(\d+)\&sec=(\d+)"'
+    CAPTCHA_PATTERN = r'"(/captchadl\.php\?[a-z0-9]+)"'
+    DL_URL_PATTERN = r'var magicomfg = \'<a href="(http://[^<>"]*?)"|"(http://storage\d+\.uploadhero\.com/\?d=[A-Za-z0-9]+/[^<>"/]+)"'
+    
+    def handleFree(self):
+        self.checkErrors() 
+        
+        found = re.search(self.CAPTCHA_PATTERN, self.html)
+        if not found: self.parseError("Captcha URL")
+        captcha_url = "http://uploadhero.com" + found.group(1)
+                      
+        for i in range(5):
+            captcha = self.decryptCaptcha(captcha_url)    
+            self.html = self.load(self.pyfile.url, get = {"code": captcha})
+            found = re.search(self.DL_URL_PATTERN, self.html) 
+            if found:
+                self.correctCaptcha()
+                download_url = found.group(1) or found.group(2)
+                break
+            else:
+                self.invalidCaptcha()
+        else:
+            self.fail("No valid captcha code entered")                  
+        
+        self.download(download_url)
+    
+    def handlePremium(self):
+        self.log.debug("%s: Use Premium Account" % self.__name__)
+        self.html = self.load(self.pyfile.url)
+        link = re.search(self.DOWNLOAD_URL_PATTERN, self.html).group(1)
+        self.log.debug("Downloading link : '%s'" % link)
+        self.download(link) 
+             
+    def checkErrors(self):
+        found = re.search(self.IP_WAIT_PATTERN, self.html)
+        if found:
+            wait_time = 30 * 60 - int(found.group(1)) * 60 - int(found.group(2))
+            self.setWait(wait_time, True)
+            self.wait()
+            self.retry()
+        
+getInfo = create_getInfo(UploadheroCom)
\ No newline at end of file
diff --git a/module/plugins/hoster/WrzucTo.py b/module/plugins/hoster/WrzucTo.py
new file mode 100644
index 000000000..4a5e89f22
--- /dev/null
+++ b/module/plugins/hoster/WrzucTo.py
@@ -0,0 +1,58 @@
+# -*- coding: utf-8 -*-
+"""
+    This program is free software; you can redistribute it and/or modify
+    it under the terms of the GNU General Public License as published by
+    the Free Software Foundation; either version 3 of the License,
+    or (at your option) any later version.
+
+    This program is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+    See the GNU General Public License for more details.
+
+    You should have received a copy of the GNU General Public License
+    along with this program; if not, see <http://www.gnu.org/licenses/>.
+
+    @author: zoidberg
+"""
+
+import re
+from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo
+from pycurl import HTTPHEADER
+
+class WrzucTo(SimpleHoster):
+    __name__ = "WrzucTo"
+    __type__ = "hoster"
+    __pattern__ = r"http://(?:\w+\.)*?wrzuc\.to/([a-zA-Z0-9]+(\.wt|\.html)|(\w+/?linki/[a-zA-Z0-9]+))"
+    __version__ = "0.01"
+    __description__ = """Wrzuc.to plugin - free only"""
+    __author_name__ = ("zoidberg")
+    __author_mail__ = ("zoidberg@mujmail.cz")
+
+    SH_COOKIES = [("http://www.wrzuc.to", "language", "en")]   
+    FILE_SIZE_PATTERN = r'class="info">\s*<tr>\s*<td>(?P<S>.*?)</td>'
+    FILE_NAME_PATTERN = r'id="file_info">\s*<strong>(?P<N>.*?)</strong>'
+    
+    def setup(self):
+        self.multiDL = True 
+    
+    def handleFree(self):
+        data = dict(re.findall(r'(md5|file): "(.*?)"', self.html))
+        if len(data) != 2: self.parseError('File ID')
+        
+        self.req.http.c.setopt(HTTPHEADER, ["X-Requested-With: XMLHttpRequest"])
+        self.req.http.lastURL = self.pyfile.url
+        self.load("http://www.wrzuc.to/ajax/server/prepair", post = {"md5": data['md5']})
+        
+        self.req.http.lastURL = self.pyfile.url
+        self.html = self.load("http://www.wrzuc.to/ajax/server/download_link", post = {"file": data['file']})
+        
+        data.update(re.findall(r'"(download_link|server_id)":"(.*?)"', self.html))
+        if len(data) != 4: self.parseError('Download URL')
+        
+        download_url = "http://%s.wrzuc.to/pobierz/%s" % (data['server_id'], data['download_link'])       
+        self.logDebug("Download URL: %s" % download_url)        
+        self.download(download_url)
+        
+getInfo = create_getInfo(WrzucTo)
+
-- 
cgit v1.2.3