# -*- coding: utf-8 -*- from Crypto.Cipher import AES from module.plugins.Crypter import Crypter from module.unescape import unescape import base64 import binascii import re class LinkSaveIn(Crypter): __name__ = "LinkSaveIn" __type__ = "crypter" __pattern__ = r"http://(www\.)?linksave.in/(?P\w+)$" __version__ = "2.0" __description__ = """LinkSave.in Crypter Plugin""" __author_name__ = ("fragonib") __author_mail__ = ("fragonib[AT]yahoo[DOT]es") # Constants _JK_KEY_ = "jk" _CRYPTED_KEY_ = "crypted" HOSTER_DOMAIN = "linksave.in" def setup(self): self.html = None self.fileid = None self.captcha = False self.package = None def decrypt(self, pyfile): # Init self.package = pyfile.package() self.fileid = re.match(self.__pattern__, pyfile.url).group('id') self.req.cj.setCookie(self.HOSTER_DOMAIN, "Linksave_Language", "english") # Request package self.html = self.load(self.pyfile.url, cookies=True) if not self.isOnline(): self.offline() # Check for protection if self.isPasswordProtected(): self.unlockPasswordProtection() self.handleErrors() if self.isCaptchaProtected(): self.captcha = True self.unlockCaptchaProtection() self.handleErrors() # Get package name and folder (package_name, folder_name) = self.getPackageInfo() # Extract package links package_links = [] package_links.extend(self.handleWebLinks()) package_links.extend(self.handleContainers()) package_links.extend(self.handleCNL2()) package_links = set(package_links) # Pack self.packages = [(package_name, package_links, folder_name)] def isOnline(self): if "Error 404 - Folder not found!" in self.html: self.log.debug("%s: File not found" % self.__name__) return False return True def isPasswordProtected(self): if re.search(r'''Captcha:" in self.html: self.log.debug("%s: Links are captcha protected" % self.__name__) return True return False def unlockPasswordProtection(self): password = self.getPassword() self.log.debug("%s: Submitting password [%s] for protected links" % (self.__name__, password)) post = {"id": self.fileid, "besucherpasswort": password, 'login': 'submit'} self.html = self.load(self.pyfile.url, post=post) def unlockCaptchaProtection(self): hash = re.search(r'name="hash" value="([^"]+)', self.html).group(1) captchaUrl = re.search(r'src=".(/captcha/cap.php\?hsh=[^"]+)', self.html).group(1) code = self.decryptCaptcha("http://linksave.in" + captchaUrl, forceUser=True) self.html = self.load(self.pyfile.url, post={"id": self.fileid, "hash": hash, "code": code}) def getPackageInfo(self): name = self.pyfile.package().name folder = self.pyfile.package().folder self.log.debug("%s: Defaulting to pyfile name [%s] and folder [%s] for package" % (self.__name__, name, folder)) return name, folder def handleErrors(self): if "The visitorpassword you have entered is wrong" in self.html: self.log.debug("%s: Incorrect password, please set right password on 'Edit package' form and retry" % self.__name__) self.fail("Incorrect password, please set right password on 'Edit package' form and retry") if self.captcha: if "Wrong code. Please retry" in self.html: self.log.debug("%s: Invalid captcha, retrying" % self.__name__) self.invalidCaptcha() self.retry() else: self.correctCaptcha() def handleWebLinks(self): package_links = [] self.log.debug("%s: Handling Web links" % self.__name__) #@TODO: Gather paginated web links pattern = r'(.*)', response)[-1] jseval = self.js.eval("document = { write: function(e) { return e; } }; %s" % jscode) dlLink = re.search(r'http://linksave\.in/dl-\w+', jseval).group(0) self.log.debug("%s: JsEngine returns value [%s] for redirection link" % (self.__name__, dlLink)) response = self.load(dlLink) link = unescape(re.search(r'