From 436ae2009b6f29e6e82914f9c13c54824b92cff1 Mon Sep 17 00:00:00 2001 From: Stefano Date: Thu, 28 Feb 2013 20:13:29 +0100 Subject: SpeedLoadOrg now uses XFileSharingPro --- module/plugins/hoster/SpeedLoadOrg.py | 65 ++++++----------------------------- 1 file changed, 11 insertions(+), 54 deletions(-) (limited to 'module/plugins/hoster') diff --git a/module/plugins/hoster/SpeedLoadOrg.py b/module/plugins/hoster/SpeedLoadOrg.py index a725d9ae0..65eead5a5 100644 --- a/module/plugins/hoster/SpeedLoadOrg.py +++ b/module/plugins/hoster/SpeedLoadOrg.py @@ -1,61 +1,18 @@ # -*- coding: utf-8 -*- -from module.plugins.internal.SimpleHoster import SimpleHoster, parseFileInfo -from module.network.RequestFactory import getURL -from module.plugins.ReCaptcha import ReCaptcha -from module.common.json_layer import json_loads -import re +from module.plugins.hoster.XFileSharingPro import XFileSharingPro, create_getInfo - -def getInfo(urls): - for url in urls: - api_data = getAPIData(url) - online = False if 'File Not Found' in api_data else True - if online: - file_info = (api_data['originalFilename'], api_data['size'], 2 , url) - else: - file_info = (url, 0, 1 , url) - yield file_info - -def getAPIData(url): - API_URL = 'http://speedload.org/api/single_link.php?shortUrl=' - - file_id = re.search(SpeedLoadOrg.__pattern__, url).group('ID') - api_data = json_loads(getURL(API_URL + file_id, decode = True)) - if isinstance(api_data, dict): - api_data['size'] = api_data['fileSize'] - - return api_data - - -class SpeedLoadOrg(SimpleHoster): +class SpeedLoadOrg(XFileSharingPro): __name__ = "SpeedLoadOrg" __type__ = "hoster" - __pattern__ = r"http://(www\.)?speedload\.org/(?P\w+).*" - __version__ = "0.06" + __pattern__ = r"http://(www\.)?speedload\.org/(?P\w+)" + __version__ = "1.00" __description__ = """Speedload.org hoster plugin""" - __author_name__ = ("z00nx", "stickell") - __author_mail__ = ("z00nx0@gmail.com", "l.stickell@yahoo.it") + __author_name__ = ("stickell") + __author_mail__ = ("l.stickell@yahoo.it") + + FILE_NAME_PATTERN = r'Filename:(?P[^<]+)' + FILE_SIZE_PATTERN = r'Size:[\w. ]+\((?P\d+) bytes\)' - FILE_NAME_PATTERN = '
' - RECAPTCHA_KEY = '6LenSdkSAAAAAJyoP5jFZl4NNell2r4rzfXRZXGW' + HOSTER_NAME = "speedload.org" - def handleFree(self): - self.api_data = getAPIData(self.pyfile.url) - recaptcha = ReCaptcha(self) - challenge, response = recaptcha.challenge(self.RECAPTCHA_KEY) - post_data = {'recaptcha_challenge_field': challenge, 'recaptcha_response_field': response, 'submit': 'continue', 'submitted': '1', 'd': '1'} - self.download(self.pyfile.url, post=post_data) - check = self.checkDownload({ - "html": re.compile("\A Date: Thu, 28 Feb 2013 20:14:22 +0100 Subject: XFileSharingPro: Cleaning the download link The detected SpeedLoadOrg download URL has a \r at the end causing a Bad Gateway error. --- module/plugins/hoster/XFileSharingPro.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'module/plugins/hoster') diff --git a/module/plugins/hoster/XFileSharingPro.py b/module/plugins/hoster/XFileSharingPro.py index 0bf7618c8..ac3e1d5de 100644 --- a/module/plugins/hoster/XFileSharingPro.py +++ b/module/plugins/hoster/XFileSharingPro.py @@ -34,7 +34,7 @@ class XFileSharingPro(SimpleHoster): __name__ = "XFileSharingPro" __type__ = "hoster" __pattern__ = r"^unmatchable$" - __version__ = "0.15" + __version__ = "0.16" __description__ = """XFileSharingPro common hoster base""" __author_name__ = ("zoidberg") __author_mail__ = ("zoidberg@mujmail.cz") @@ -184,6 +184,7 @@ class XFileSharingPro(SimpleHoster): self.retry() def startDownload(self, link): + link = link.strip() if self.captcha: self.correctCaptcha() self.logDebug('DIRECT LINK: %s' % link) self.download(link) @@ -301,4 +302,4 @@ class XFileSharingPro(SimpleHoster): return 3 return 0 -getInfo = create_getInfo(XFileSharingPro) \ No newline at end of file +getInfo = create_getInfo(XFileSharingPro) -- cgit v1.2.3