# -*- coding: utf-8 -*-
import re
from urlparse import urljoin
from module.plugins.internal.SimpleHoster import SimpleHoster, create_getInfo
class FileSharkPl(SimpleHoster):
__name__ = "FileSharkPl"
__type__ = "hoster"
__version__ = "0.09"
__pattern__ = r'http://(?:www\.)?fileshark\.pl/pobierz/\d+/\w+'
__description__ = """FileShark.pl hoster plugin"""
__license__ = "GPLv3"
__authors__ = [("prOq", None),
("Walter Purcaro", "vuolter@gmail.com")]
NAME_PATTERN = r'
(?P.+)
'
SIZE_PATTERN = r'(.*?)(?P\d+\.?\d*)\s(?P\w+)
'
OFFLINE_PATTERN = r'(P|p)lik zosta. (usuni.ty|przeniesiony)'
LINK_FREE_PATTERN = r''
LINK_PREMIUM_PATTERN = r''
WAIT_PATTERN = r'var timeToDownload = (\d+);'
ERROR_PATTERN = r'(.*?)
'
IP_ERROR_PATTERN = r'Strona jest dost.pna wy..cznie dla u.ytkownik.w znajduj.cych si. na terenie Polski'
SLOT_ERROR_PATTERN = r'Osi.gni.to maksymaln. liczb. .ci.ganych jednocze.nie plik.w\.'
CAPTCHA_PATTERN = r'
'
def setup(self):
self.resumeDownload = True
if self.premium:
self.multiDL = True
self.limitDL = 20
else:
self.multiDL = False
def checkErrors(self):
# check if file is now available for download (-> file name can be found in html body)
m = re.search(self.WAIT_PATTERN, self.html)
if m:
errmsg = self.info['error'] = _("Another download already run")
self.retry(15, int(m.group(1)), errmsg)
m = re.search(self.ERROR_PATTERN, self.html)
if m:
alert = m.group(1)
if re.match(self.IP_ERROR_PATTERN, alert):
self.fail(_("Only connections from Polish IP are allowed"))
elif re.match(self.SLOT_ERROR_PATTERN, alert):
errmsg = self.info['error'] = _("No free download slots available")
self.logWarning(errmsg)
self.retry(10, 30 * 60, _("Still no free download slots available"))
else:
self.info['error'] = alert
self.retry(10, 10 * 60, _("Try again later"))
self.info.pop('error', None)
def handleFree(self, pyfile):
m = re.search(self.LINK_FREE_PATTERN, self.html)
if m is None:
self.error(_("Download url not found"))
link = urljoin("http://fileshark.pl", m.group(1))
self.html = self.load(link)
m = re.search(self.WAIT_PATTERN, self.html)
if m:
seconds = int(m.group(1))
self.logDebug("Wait %s seconds" % seconds)
self.wait(seconds)
action, inputs = self.parseHtmlForm('action=""')
m = re.search(self.TOKEN_PATTERN, self.html)
if m is None:
self.retry(reason=_("Captcha form not found"))
inputs['form[_token]'] = m.group(1)
m = re.search(self.CAPTCHA_PATTERN, self.html)
if m is None:
self.retry(reason=_("Captcha image not found"))
tmp_load = self.load
self.load = self._decode64 #: work-around: injects decode64 inside decryptCaptcha
inputs['form[captcha]'] = self.decryptCaptcha(m.group(1), imgtype='jpeg')
inputs['form[start]'] = ""
self.load = tmp_load
self.download(link, post=inputs, disposition=True)
def _decode64(self, data, *args, **kwargs):
return data.decode('base64')
getInfo = create_getInfo(FileSharkPl)