summaryrefslogtreecommitdiffstats
path: root/module
diff options
context:
space:
mode:
Diffstat (limited to 'module')
-rwxr-xr-xmodule/network/Request.py14
-rw-r--r--module/plugins/UploadedTo.py47
2 files changed, 49 insertions, 12 deletions
diff --git a/module/network/Request.py b/module/network/Request.py
index 742111a2a..092e75a01 100755
--- a/module/network/Request.py
+++ b/module/network/Request.py
@@ -93,9 +93,6 @@ class Request:
self.pycurl.setopt(pycurl.CONNECTTIMEOUT, 30)
self.pycurl.setopt(pycurl.NOSIGNAL, 1)
self.pycurl.setopt(pycurl.NOPROGRESS, 0)
- cookie_file = "module" + sep + "cookies.txt"
- self.pycurl.setopt(pycurl.COOKIEFILE, cookie_file)
- self.pycurl.setopt(pycurl.COOKIEJAR, cookie_file)
self.pycurl.setopt(pycurl.PROGRESSFUNCTION, self.progress)
self.pycurl.setopt(pycurl.AUTOREFERER, 1)
self.pycurl.setopt(pycurl.HEADERFUNCTION, self.write_header)
@@ -127,6 +124,9 @@ class Request:
self.pycurl.setopt(pycurl.URL, url)
self.pycurl.setopt(pycurl.WRITEFUNCTION, self.rep.write)
+
+ if cookies:
+ self.curl_enable_cookies()
if post: self.pycurl.setopt(pycurl.POSTFIELDS, post)
@@ -167,6 +167,11 @@ class Request:
return output
+ def curl_enable_cookies(self):
+ cookie_file = "module" + sep + "cookies.txt"
+ self.pycurl.setopt(pycurl.COOKIEFILE, cookie_file)
+ self.pycurl.setopt(pycurl.COOKIEJAR, cookie_file)
+
def add_auth(self, user, pw):
self.auth = True
@@ -228,6 +233,9 @@ class Request:
self.pycurl.setopt(pycurl.URL, url)
self.pycurl.setopt(pycurl.WRITEDATA, fp)
+
+ if cookies:
+ self.curl_enable_cookies()
if post: self.pycurl.setopt(pycurl.POSTFIELDS, post)
diff --git a/module/plugins/UploadedTo.py b/module/plugins/UploadedTo.py
index e65be789c..50ea01459 100644
--- a/module/plugins/UploadedTo.py
+++ b/module/plugins/UploadedTo.py
@@ -13,26 +13,35 @@ class UploadedTo(Plugin):
props['name'] = "UploadedTo"
props['type'] = "hoster"
props['pattern'] = r"http://(?:www\.)?u(?:p)?l(?:oaded)?\.to/"
- props['version'] = "0.1"
+ props['version'] = "0.2"
props['description'] = """Uploaded.to Download Plugin"""
- props['author_name'] = ("spoob")
- props['author_mail'] = ("spoob@pyload.org")
+ props['author_name'] = ("spoob", "mkaay")
+ props['author_mail'] = ("spoob@pyload.org", "mkaay@mkaay.de")
self.props = props
self.parent = parent
self.html = None
self.html_old = None #time() where loaded the HTML
self.time_plus_wait = None #time() + wait in seconds
- self.want_reconnect = None
- self.multi_dl = False
+
+ self.want_reconnect = False
+
+ self.read_config()
+ if self.config['premium']:
+ self.multi_dl = True
+ else:
+ self.multi_dl = False
+
+ self.start_dl = False
def prepare(self, thread):
pyfile = self.parent
-
+
self.want_reconnect = False
tries = 0
while not pyfile.status.url:
-
+
+ self.req.clear_cookies()
self.download_html()
pyfile.status.exists = self.file_exists()
@@ -41,6 +50,12 @@ class UploadedTo(Plugin):
raise Exception, "The file was not found on the server."
pyfile.status.filename = self.get_file_name()
+
+ if self.config['premium']:
+ pyfile.status.url = self.parent.url
+ return True
+
+ self.get_waiting_time()
pyfile.status.waituntil = self.time_plus_wait
pyfile.status.url = self.get_file_url()
@@ -55,11 +70,15 @@ class UploadedTo(Plugin):
raise Exception, "Error while preparing DL, HTML dump: %s" % self.html
return True
-
+
def download_html(self):
+ if self.config['premium']:
+ self.config['username'], self.config['password']
+ self.req.load("http://uploaded.to/login", None, { "email" : self.config['username'], "password" : self.config['password']})
url = self.parent.url
- self.html = self.req.load(url)
+ self.html = self.req.load(url, cookies=False)
+ def get_waiting_time(self):
try:
wait_minutes = re.search(r"Or wait ([\d\-]+) minutes", self.html).group(1)
if int(wait_minutes) < 0: wait_minutes = 1
@@ -71,6 +90,10 @@ class UploadedTo(Plugin):
def get_file_url(self):
""" returns the absolute downloadable filepath
"""
+ if self.config['premium']:
+ self.start_dl = True
+ return self.parent.url
+
try:
file_url_pattern = r".*<form name=\"download_form\" method=\"post\" action=\"(.*)\">"
return re.search(file_url_pattern, self.html).group(1)
@@ -95,3 +118,9 @@ class UploadedTo(Plugin):
return False
else:
return True
+
+ def proceed(self, url, location):
+ if self.config['premium']:
+ self.req.download(url, location, cookies=True)
+ else:
+ self.req.download(url, location, cookies=False, post={"download_submit": "Free Download"})