diff options
Diffstat (limited to 'module/plugins/crypter/NCryptIn.py')
-rw-r--r-- | module/plugins/crypter/NCryptIn.py | 87 |
1 files changed, 44 insertions, 43 deletions
diff --git a/module/plugins/crypter/NCryptIn.py b/module/plugins/crypter/NCryptIn.py index 821636821..6e0c35e92 100644 --- a/module/plugins/crypter/NCryptIn.py +++ b/module/plugins/crypter/NCryptIn.py @@ -1,17 +1,19 @@ # -*- coding: utf-8 -*- -from Crypto.Cipher import AES -from module.plugins.Crypter import Crypter -from module.plugins.ReCaptcha import ReCaptcha import base64 import binascii import re +from Crypto.Cipher import AES +from module.plugins.Crypter import Crypter +from module.plugins.ReCaptcha import ReCaptcha + + class NCryptIn(Crypter): __name__ = "NCryptIn" __type__ = "crypter" __pattern__ = r"http://(?:www\.)?ncrypt.in/folder-([^/\?]+)" - __version__ = "1.22" + __version__ = "1.23" __description__ = """NCrypt.in Crypter Plugin""" __author_name__ = ("fragonib") __author_mail__ = ("fragonib[AT]yahoo[DOT]es") @@ -19,7 +21,7 @@ class NCryptIn(Crypter): # Constants _JK_KEY_ = "jk" _CRYPTED_KEY_ = "crypted" - + def setup(self): self.html = None self.cleanedHtml = None @@ -27,16 +29,16 @@ class NCryptIn(Crypter): self.package = None def decrypt(self, pyfile): - + # Init self.package = pyfile.package() - + # Request package self.html = self.load(self.pyfile.url) self.cleanedHtml = self.removeCrap(self.html) if not self.isOnline(): self.offline() - + # Check for protection if self.isProtected(): self.html = self.unlockProtection() @@ -50,13 +52,13 @@ class NCryptIn(Crypter): package_links = [] package_links.extend(self.handleWebLinks()) package_links.extend(self.handleContainers()) - package_links.extend(self.handleCNL2()) + package_links.extend(self.handleCNL2()) package_links = self.removeContainers(package_links) package_links = set(package_links) # Pack self.packages = [(package_name, package_links, folder_name)] - + def removeCrap(self, content): patterns = (r'(type="hidden".*?(name=".*?")?.*?value=".*?")', r'display:none;">(.*?)</(div|span)>', @@ -67,8 +69,8 @@ class NCryptIn(Crypter): content = re.sub(rexpr, "", content) return content - def removeContainers(self,package_links): - tmp_package_links = package_links[:] + def removeContainers(self, package_links): + tmp_package_links = package_links[:] for link in tmp_package_links: self.logDebug(link) if ".dlc" in link or ".ccf" in link or ".rsdf" in link: @@ -80,18 +82,18 @@ class NCryptIn(Crypter): else: return tmp_package_links - def isOnline(self): + def isOnline(self): if "Your folder does not exist" in self.cleanedHtml: self.logDebug("File not found") return False return True - + def isProtected(self): if re.search(r'''<form.*?name.*?protected.*?>''', self.cleanedHtml): self.logDebug("Links are protected") return True return False - + def getPackageInfo(self): title_re = r'<h2><span.*?class="arrow".*?>(?P<title>[^<]+).*?</span>.*?</h2>' m = re.findall(title_re, self.html, re.DOTALL) @@ -104,19 +106,19 @@ class NCryptIn(Crypter): folder = self.package.folder self.logDebug("Package info not found, defaulting to pyfile name [%s] and folder [%s]" % (name, folder)) return name, folder - + def unlockProtection(self): - + postData = {} - - form = re.search(r'''<form\ name="protected"(.*?)</form>''', self.cleanedHtml, re.DOTALL).group(1) - + + form = re.search(r'<form name="protected"(.*?)</form>', self.cleanedHtml, re.DOTALL).group(1) + # Submit package password if "password" in form: password = self.getPassword() self.logDebug("Submitting password [%s] for protected links" % password) postData['password'] = password - + # Resolve anicaptcha if "anicaptcha" in form: self.captcha = True @@ -125,10 +127,10 @@ class NCryptIn(Crypter): captcha = self.decryptCaptcha("http://ncrypt.in" + captchaUri) self.logDebug("Captcha resolved [%s]" % captcha) postData['captcha'] = captcha - + # Resolve recaptcha if "recaptcha" in form: - self.captcha = True + self.captcha = True id = re.search(r'\?k=(.*?)"', form).group(1) self.logDebug("Resolving ReCaptcha with key [%s]" % id) recaptcha = ReCaptcha(self) @@ -148,18 +150,17 @@ class NCryptIn(Crypter): postData['circle.x'] = coords[0] postData['circle.y'] = coords[1] - # Unlock protection postData['submit_protected'] = 'Continue to folder ' return self.load(self.pyfile.url, post=postData) - + def handleErrors(self): - + if "This password is invalid!" in self.cleanedHtml: self.logDebug("Incorrect password, please set right password on 'Edit package' form and retry") - self.fail("Incorrect password, please set right password on 'Edit package' form and retry") + self.fail("Incorrect password, please set right password on 'Edit package' form and retry") - if self.captcha: + if self.captcha: if "The securitycheck was wrong!" in self.cleanedHtml: self.logDebug("Invalid captcha, retrying") self.invalidCaptcha() @@ -170,24 +171,24 @@ class NCryptIn(Crypter): def handleWebLinks(self): package_links = [] self.logDebug("Handling Web links") - + pattern = r"(http://ncrypt\.in/link-.*?=)" links = re.findall(pattern, self.html) self.logDebug("Decrypting %d Web links" % len(links)) for i, link in enumerate(links): - self.logDebug("Decrypting Web link %d, %s" % (i+1, link)) + self.logDebug("Decrypting Web link %d, %s" % (i + 1, link)) try: url = link.replace("link-", "frame-") link = self.load(url, just_header=True)['location'] package_links.append(link) except Exception, detail: - self.logDebug("Error decrypting Web link %s, %s" % (link, detail)) + self.logDebug("Error decrypting Web link %s, %s" % (link, detail)) return package_links - + def handleContainers(self): package_links = [] self.logDebug("Handling Container links") - + pattern = r"/container/(rsdf|dlc|ccf)/([a-z0-9]+)" containersLinks = re.findall(pattern, self.html) self.logDebug("Decrypting %d Container links" % len(containersLinks)) @@ -195,30 +196,30 @@ class NCryptIn(Crypter): link = "http://ncrypt.in/container/%s/%s.%s" % (containerLink[0], containerLink[1], containerLink[0]) package_links.append(link) return package_links - + def handleCNL2(self): package_links = [] self.logDebug("Handling CNL2 links") - + if 'cnl2_output' in self.cleanedHtml: try: (vcrypted, vjk) = self._getCipherParams() for (crypted, jk) in zip(vcrypted, vjk): package_links.extend(self._getLinks(crypted, jk)) except: - self.fail("Unable to decrypt CNL2 links") + self.fail("Unable to decrypt CNL2 links") return package_links - + def _getCipherParams(self): - - pattern = r'<input.*?name="%s".*?value="(.*?)"' - + + pattern = r'<input.*?name="%s".*?value="(.*?)"' + # Get jk - jk_re = pattern % NCryptIn._JK_KEY_ + jk_re = pattern % NCryptIn._JK_KEY_ vjk = re.findall(jk_re, self.html) - + # Get crypted - crypted_re = pattern % NCryptIn._CRYPTED_KEY_ + crypted_re = pattern % NCryptIn._CRYPTED_KEY_ vcrypted = re.findall(crypted_re, self.html) # Log and return |