diff options
author | Stefano <l.stickell@yahoo.it> | 2014-07-09 12:35:08 +0200 |
---|---|---|
committer | Stefano <l.stickell@yahoo.it> | 2014-07-09 12:35:08 +0200 |
commit | b3c5ce5dadf086b99c524bf454fb979733243da0 (patch) | |
tree | 66baccf8039f9fc8dc3864292a50018b8838d26c /module/plugins/hoster/LomafileCom.py | |
parent | Merge pull request #681 from thuvh/patch-1 (diff) | |
download | pyload-b3c5ce5dadf086b99c524bf454fb979733243da0.tar.xz |
[Lomafile] new hoster
Diffstat (limited to 'module/plugins/hoster/LomafileCom.py')
-rw-r--r-- | module/plugins/hoster/LomafileCom.py | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/module/plugins/hoster/LomafileCom.py b/module/plugins/hoster/LomafileCom.py new file mode 100644 index 000000000..5ce41264b --- /dev/null +++ b/module/plugins/hoster/LomafileCom.py @@ -0,0 +1,55 @@ +import re + +from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo + + +class LomafileCom(SimpleHoster): + __name__ = "LomafileCom" + __type__ = "hoster" + __pattern__ = r'https?://lomafile\.com/.+/[\w\.]+' + __version__ = "0.1" + __description__ = """Lomafile.com hoster plugin""" + __author_name__ = "nath_schwarz" + __author_mail__ = "nathan.notwhite@gmail.com" + + FILE_NAME_PATTERN = r'Filename:[^>]*>(?P<N>[\w\.]+)' + FILE_SIZE_PATTERN = r'\((?P<S>\d+)\s(?P<U>\w+)\)' + FILE_OFFLINE_PATTERN = r'Software error' + + def handleFree(self): + for _ in range(3): + captcha_id = re.search(r'src="http://lomafile\.com/captchas/(?P<id>\w+)\.jpg"', self.html) + if not captcha_id: + self.parseError("Unable to parse captcha id.") + else: + captcha_id = captcha_id.group("id") + + form_id = re.search(r'name="id" value="(?P<id>\w+)"', self.html) + if not form_id: + self.parseError("Unable to parse form id") + else: + form_id = form_id.group("id") + + captcha = self.decryptCaptcha("http://lomafile.com/captchas/" + captcha_id + ".jpg") + + self.wait(60) + + self.html = self.load(self.pyfile.url, post={ + "op": "download2", + "id": form_id, + "rand": captcha_id, + "code": captcha, + "down_direct": "1"}) + + download_url = re.search(r'http://[\d\.]+:\d+/d/\w+/[\w\.]+', self.html) + if not download_url: + self.invalidCaptcha() + self.logDebug("Invalid captcha.") + else: + download_url = download_url.group(0) + self.logDebug("Download URL: %s" % download_url) + self.download(download_url) + else: + self.fail("Invalid captcha-code entered.") + +getInfo = create_getInfo(LomafileCom) |