From 693e128fab887410f6df58af8430532fdf109f33 Mon Sep 17 00:00:00 2001 From: zoidberg10 Date: Sat, 14 Apr 2012 23:31:55 +0200 Subject: update dlfree.fr, letitbit.net, easybytez.com - closed #566, #574 --- module/plugins/hoster/DlFreeFr.py | 29 ++++++++++++++++++++--------- 1 file changed, 20 insertions(+), 9 deletions(-) (limited to 'module/plugins/hoster/DlFreeFr.py') diff --git a/module/plugins/hoster/DlFreeFr.py b/module/plugins/hoster/DlFreeFr.py index 138d0e056..a8b5eb3e8 100644 --- a/module/plugins/hoster/DlFreeFr.py +++ b/module/plugins/hoster/DlFreeFr.py @@ -3,20 +3,23 @@ import re from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo +from module.plugins.ReCaptcha import ReCaptcha class DlFreeFr(SimpleHoster): __name__ = "DlFreeFr" __type__ = "hoster" - __pattern__ = r"http://dl\.free\.fr/([a-zA-Z0-9]+|getfile\.pl\?file=/[a-zA-Z0-9]+)$" - __version__ = "0.2" + __pattern__ = r"http://dl\.free\.fr/([a-zA-Z0-9]+|getfile\.pl\?file=/[a-zA-Z0-9]+)" + __version__ = "0.21" __description__ = """dl.free.fr download hoster""" __author_name__ = ("the-razer", "zoidberg") __author_mail__ = ("daniel_ AT gmx DOT net", "zoidberg@mujmail.cz") FILE_NAME_PATTERN = r"Fichier:\s*]*>(?P[^>]*)" - FILE_SIZE_PATTERN = r"Taille:\s*]*>(?P[\d.]+[KMG])" + FILE_SIZE_PATTERN = r"Taille:\s*]*>(?P[\d.]+[KMG])o" FILE_OFFLINE_PATTERN = r"Erreur 404 - Document non trouv|Fichier inexistant|Le fichier demandé n'a pas été trouvé" - FILE_URL_PATTERN = r'href="(?Phttp://.*?)">Télécharger ce fichier' + #FILE_URL_PATTERN = r'href="(?Phttp://.*?)">Télécharger ce fichier' + + RECAPTCHA_KEY_PATTERN = r'"recaptcha":{"key":"(.*?)"}' def setup(self): self.multiDL = True @@ -27,12 +30,20 @@ class DlFreeFr(SimpleHoster): def handleFree(self): if "Trop de slots utilisés" in self.html: self.retry(300) + + recaptcha_key = '6Lf-Ws8SAAAAAAO4ND_KCqpZzNZQKYEuOROs4edG' + found = re.search(self.RECAPTCHA_KEY_PATTERN, self.html) + if found: recaptcha_key = found.group(1) + + action, inputs = self.parseHtmlForm('action="getfile.pl"') + inputs.update( {"_ayl_captcha_engine" : "recaptcha", + "_ayl_env" : "prod", + "_ayl_tid" : "undefined", + "_ayl_token_challenge" : "undefined"} ) - m = re.search(self.FILE_URL_PATTERN, self.html) - if not m: self.parseError('URL') + recaptcha = ReCaptcha(self) + inputs['recaptcha_challenge_field'], inputs['recaptcha_response_field'] = recaptcha.challenge(recaptcha_key) - url = m.group('url') - self.logDebug("File URL [%s]" % url) - self.download(url) + self.download("http://dl.free.fr/getfile.pl", post = inputs) getInfo = create_getInfo(DlFreeFr) \ No newline at end of file -- cgit v1.2.3