#!/usr/bin/env python
# -*- coding: utf-8 -*-
import re
from module.plugins.Hoster import Hoster
from module.plugins.ReCaptcha import ReCaptcha
from module.plugins.Plugin import chunks
from module.network.RequestFactory import getURL
from module.utils import decode
def getInfo(urls):
for chunk in chunks(urls, 15):
# Always use "filesonic.com" for file's url
# mod_link contains the right url to check
orig_link = "".join(chunk)
mod_link = orig_link
url_datas = re.search("(.+)(filesonic\..+)/file/(.+)", orig_link)
if url_datas:
mod_link = url_datas.group(1) + "filesonic.com" + "/file/" + url_datas.group(3)
page = getURL("http://www." + getDomain() + "/link-checker", post={"links": mod_link}).decode("utf8", "ignore")
found = re.findall(r'
\s+([^<]+) | \s+([^<]+) | \s+(.+) MB | \s+\s+([^<]+) \s+\s+ | \s+
', page, re.MULTILINE)
result = []
for src, name, size, status in found:
result.append((name, float(size)*1024*1024, 2 if status == "Available" else 1, src))
yield result
def getDomain():
html = decode(getURL("http://api.filesonic.com/utility?method=getFilesonicDomainForCurrentIp&format=xml"))
return re.search(r"response>.*?(filesonic\..*?)Download (.*?) for free on Filesonic.com', self.html)
if name:
self.pyfile.name = name.group(1)
else:
self.offline()
if 'The page you are trying to access was not found.' in self.html:
self.offline()
if self.account:
self.download(pyfile.url)
else:
self.download(self.getFileUrl())
def getFileUrl(self):
part_1_link = re.search("(.+/file/\d+/)", self.url).group(1)
link = part_1_link + re.search(r'href="(.*?start=1.*?)"', self.html).group(1)
self.html = self.load(link)
self.handleErrors()
realLinkRegexp = "Start download now!
"
url = re.search(realLinkRegexp, self.html)
if not url:
if "This file is available for premium users only." in self.html:
self.fail("Need premium account.")
countDownDelay = re.search("countDownDelay = (\\d+)", self.html)
if countDownDelay:
wait_time = int(countDownDelay.group(1))
if wait_time > 300:
self.wantReconnect = True
self.setWait(wait_time)
self.log.info("%s: Waiting %d seconds." % (self.__name__, wait_time))
self.wait()
tm = re.search("name='tm' value='(.*?)' />", self.html)
tm_hash = re.search("name='tm_hash' value='(.*?)' />", self.html)
if tm and tm_hash:
tm = tm.group(1)
tm_hash = tm_hash.group(1)
else:
self.html = self.load(link)
self.handleErrors()
url = re.search(realLinkRegexp, self.html)
if not url:
if "This file is available for premium users only." in self.html:
self.fail("Need premium account.")
countDownDelay = re.search("countDownDelay = (\\d+)", self.html)
if countDownDelay:
wait_time = int(countDownDelay.group(1))
if wait_time > 300:
self.wantReconnect = True
self.setWait(wait_time)
self.log.info("%s: Waiting %d seconds." % (self.__name__, wait_time))
self.wait()
tm = re.search("name='tm' value='(.*?)' />", self.html).group(1)
tm_hash = re.search("name='tm_hash' value='(.*?)' />", self.html).group(1)
self.html = self.load(self.url + "?start=1", post={"tm":tm,"tm_hash":tm_hash})
self.handleErrors()
if "Please Enter Password" in self.html:
self.fail("implement need pw")
chall = re.search(r'Recaptcha.create\("(.*?)",', self.html)
for i in range(5):
if not chall: break
re_captcha = ReCaptcha(self)
challenge, result = re_captcha.challenge(chall.group(1))
postData = {"recaptcha_challenge_field": challenge,
"recaptcha_response_field" : result}
self.html = self.load(link, post=postData)
chall = re.search(r'Recaptcha.create\("(.*?)",', self.html)
if chall:
self.invalidCaptcha()
else:
self.correctCaptcha()
re_url = re.search(realLinkRegexp, self.html)
if re_url:
url = re_url.group(1)
if not url:
self.fail("Plugin failed")
return url
def convertURL(self, url):
id = re.search("/file/([0-9]+(/.+)?)", url)
if not id:
id = re.search("/file/[a-z0-9]+/([0-9]+(/.+)?)", url)
result = "http://www.filesonic.com/file/" + id.group(1)
return self.getRightUrl(result)
def handleErrors(self):
if "The file that you're trying to download is larger than" in self.html:
self.fail("need premium account for file")
if "Free users may only download 1 file at a time" in self.html:
self.fail("only 1 file at a time for free users")
if "Free user can not download files" in self.html:
self.fail("need premium account for file")
if "Download session in progress" in self.html:
self.fail("already downloading")
if "This file is password protected" in self.html:
self.fail("This file is password protected, please one.")
if "An Error Occurred" in self.html:
self.fail("A server error occured.")
if "This file was deleted" in self.html:
self.offline()
def getRightUrl(self, url):
part_2 = re.search("http://www..+(/file.+)", url)
if not part_2:
part_2 = re.search("http://.+(/file.+)", url)
return "http://www.%s%s" % (getDomain(), part_2.group(1))