#!/usr/bin/env python
# -*- coding: utf-8 -*-
import re
from time import time
from urllib import unquote
from module.plugins.Hoster import Hoster
from module.plugins.ReCaptcha import ReCaptcha
from module.network.RequestFactory import getURL
from module.plugins.Plugin import chunks
def getInfo(urls):
api_url_base = "http://api.hotfile.com/"
for chunk in chunks(urls, 90):
api_param_file = {"action":"checklinks","links": ",".join(chunk),"fields":"id,status,name,size"} #api only supports old style links
src = getURL(api_url_base, post=api_param_file)
result = []
for i, res in enumerate(src.split("\n")):
if not res:
continue
fields = res.split(",")
if fields[1] in ("1", "2"):
status = 2
else:
status = 1
result.append((fields[2], int(fields[3]), status, chunk[i]))
yield result
class HotfileCom(Hoster):
__name__ = "HotfileCom"
__type__ = "hoster"
__pattern__ = r"http://(www.)?hotfile\.com/dl/\d+/[0-9a-zA-Z]+/"
__version__ = "0.3"
__description__ = """Hotfile.com Download Hoster"""
__author_name__ = ("sitacuisses","spoob","mkaay")
__author_mail__ = ("sitacuisses@yhoo.de","spoob@pyload.org","mkaay@mkaay.de")
def setup(self):
self.html = [None, None]
self.wantReconnect = False
self.multiDL = False
self.htmlwithlink = None
self.url = None
if self.account:
self.multiDL = True
self.req.canContinue = True
def apiCall(self, method, post, login=False):
if not self.account and login:
return
elif self.account and login:
return self.account.apiCall(method, post, self.user)
post.update({"action": method})
return self.load("http://api.hotfile.com/", post=post)
def process(self, pyfile):
self.wantReconnect = False
args = {"links":self.pyfile.url, "fields":"id,status,name,size,sha1"}
resp = self.apiCall("checklinks", args)
self.apiData = {}
for k, v in zip(args["fields"].split(","), resp.strip().split(",")):
self.apiData[k] = v
if self.apiData["status"] == "0":
self.offline()
pyfile.name = self.apiData["name"]
if not self.account:
self.downloadHTML()
self.setWait(self.getWaitTime())
self.wait()
self.freeDownload()
else:
dl = self.account.apiCall("getdirectdownloadlink", {"link":self.pyfile.url}, self.user)
dl = unquote(dl).strip()
self.download(dl)
def downloadHTML(self):
self.html[0] = self.load(self.pyfile.url, get={"lang":"en"}, cookies=True)
def freeDownload(self):
form_content = re.search(r"<form style=.*(\n<.*>\s*)*?\n<tr>", self.html[0]).group(0)
form_posts = re.findall(r"<input\stype=hidden\sname=(\S*)\svalue=(\S*)>", form_content)
self.html[1] = self.load(self.pyfile.url, post=form_posts, cookies=True)
challenge = re.search(r"http://api\.recaptcha\.net/challenge\?k=([0-9A-Za-z]+)", self.html[1])
if challenge:
re_captcha = ReCaptcha(self)
challenge, result = re_captcha.challenge(challenge.group(1))
url = re.search(r'<form action="(/dl/[^"]+)', self.html[1] )
self.html[1] = self.load("http://hotfile.com"+url.group(1), post={"action": "checkcaptcha",
"recaptcha_challenge_field" : challenge,
"recaptcha_response_field": result})
if "Wrong Code. Please try again." in self.html[1]:
self.freeDownload()
return
file_url = re.search(r'a href="(http://hotfile\.com/get/\S*)"', self.html[1]).group(1)
self.download(file_url)
def getWaitTime(self):
free_limit_pattern = re.compile(r"timerend=d\.getTime\(\)\+(\d+);")
matches = free_limit_pattern.findall(self.html[0])
if matches:
for match in matches:
if int(match) == 60000:
continue
if int(match) == 0:
continue
else:
self.wantReconnect = True
return int(match)/1000 + 65
return 65