summaryrefslogtreecommitdiffstats
path: root/module/plugins/hoster
diff options
context:
space:
mode:
authorGravatar mkaay <mkaay@mkaay.de> 2011-06-15 12:41:16 +0200
committerGravatar mkaay <mkaay@mkaay.de> 2011-06-15 12:41:16 +0200
commit5352b4bf8c58f2c55bd36d5e6fe46c9adeac5164 (patch)
tree20ba35d850e06ef27bc771299c39522b1d125028 /module/plugins/hoster
parentfixed hoerbuch.in plugin (closes #328) (diff)
downloadpyload-5352b4bf8c58f2c55bd36d5e6fe46c9adeac5164.tar.xz
hagg's rapidshare patch
Diffstat (limited to 'module/plugins/hoster')
-rw-r--r--module/plugins/hoster/RapidshareCom.py50
1 files changed, 21 insertions, 29 deletions
diff --git a/module/plugins/hoster/RapidshareCom.py b/module/plugins/hoster/RapidshareCom.py
index c02a69b81..95f6f91f9 100644
--- a/module/plugins/hoster/RapidshareCom.py
+++ b/module/plugins/hoster/RapidshareCom.py
@@ -2,6 +2,11 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
+# v1.35
+# * fixed rs-urls in handleFree(..) and freeWait(..)
+# * removed getInfo(..) function as it was not used anywhere (in this file)
+# * removed some (old?) comment blocks
+
import re
from os import stat, remove
from time import sleep
@@ -10,7 +15,6 @@ from module.network.RequestFactory import getURL
from module.plugins.Hoster import Hoster
def getInfo(urls):
-
ids = ""
names = ""
@@ -24,11 +28,9 @@ def getInfo(urls):
elif r.group("name_new"):
ids+= ","+r.group("id_new")
names+= ","+r.group("name_new")
-
url = "http://api.rapidshare.com/cgi-bin/rsapi.cgi?sub=checkfiles_v1&files=%s&filenames=%s" % (ids[1:], names[1:])
-
api = getURL(url)
result = []
i = 0
@@ -38,16 +40,17 @@ def getInfo(urls):
elif tmp[4] == "1": status = 2
else: status = 3
- result.append( (tmp[1], tmp[2], status, urls[i]) )
+ result.append( (tmp[1], tmp[2], status, urls[i]) )
i += 1
yield result
+
class RapidshareCom(Hoster):
__name__ = "RapidshareCom"
__type__ = "hoster"
__pattern__ = r"https?://[\w\.]*?rapidshare.com/(?:files/(?P<id>\d*?)/(?P<name>[^?]+)|#!download\|(?:\w+)\|(?P<id_new>\d+)\|(?P<name_new>[^|]+))"
- __version__ = "1.34"
+ __version__ = "1.35"
__description__ = """Rapidshare.com Download Hoster"""
__config__ = [["server", "Cogent;Deutsche Telekom;Level(3);Level(3) #2;GlobalCrossing;Level(3) #3;Teleglobe;GlobalCrossing #2;TeliaSonera #2;Teleglobe #2;TeliaSonera #3;TeliaSonera", "Preferred Server", "None"]]
__author_name__ = ("spoob", "RaNaN", "mkaay")
@@ -74,9 +77,6 @@ class RapidshareCom(Hoster):
self.prepare()
def prepare(self):
- # self.no_slots = True
- # self.want_reconnect = False
-
m = re.search(self.__pattern__, self.url)
if m.group("name"):
@@ -98,14 +98,9 @@ class RapidshareCom(Hoster):
elif self.api_data["status"] == "2":
self.log.info(_("Rapidshare: Traffic Share (direct download)"))
self.pyfile.name = self.get_file_name()
- # self.pyfile.status.url = self.parent.url
self.download(self.pyfile.url, get={"directstart":1}, cookies=True)
-
-# elif int(self.api_data["status"]) >= 50 and int(self.api_data["status"]) < 100:
-# self.pyfile.name = self.get_file_name()
-# self.download(self.pyfile.url)
-
+
elif self.api_data["status"] in ("0","4","5"):
self.offline()
else:
@@ -116,9 +111,10 @@ class RapidshareCom(Hoster):
while self.no_download:
self.dl_dict = self.freeWait()
- tmp = "#!download|%(server)s|%(id)s|%(name)s|%(size)s"
- download = "http://%(host)s/cgi-bin/rsapi.cgi?sub=download_v1&editparentlocation=1&bin=1&fileid=%(id)s&filename=%(name)s&dlauth=%(auth)s" % self.dl_dict
+ #tmp = "#!download|%(server)s|%(id)s|%(name)s|%(size)s"
+ download = "http://%(host)s/cgi-bin/rsapi.cgi?sub=download&editparentlocation=0&bin=1&fileid=%(id)s&filename=%(name)s&dlauth=%(auth)s" % self.dl_dict
+ self.log.debug("RS API Request: %s" % download)
self.download(download, ref=False)
check = self.checkDownload({"ip" : "You need RapidPro to download more files from your IP address",
@@ -155,13 +151,13 @@ class RapidshareCom(Hoster):
fields = src.split(",")
"""
status codes:
-0=File not found
- 1=File OK (Anonymous downloading)
- 3=Server down
- 4=File marked as illegal
- 5=Anonymous file locked, because it has more than 10 downloads already
- 50+n=File OK (TrafficShare direct download type "n" without any logging.)
- 100+n=File OK (TrafficShare direct download type "n" with logging. Read our privacy policy to see what is logged.)
+ 0=File not found
+ 1=File OK (Anonymous downloading)
+ 3=Server down
+ 4=File marked as illegal
+ 5=Anonymous file locked, because it has more than 10 downloads already
+ 50+n=File OK (TrafficShare direct download type "n" without any logging.)
+ 100+n=File OK (TrafficShare direct download type "n" with logging. Read our privacy policy to see what is logged.)
"""
self.api_data = {"fileid": fields[0], "filename": fields[1], "size": int(fields[2]), "serverid": fields[3],
"status": fields[4], "shorthost": fields[5], "checksum": fields[6].strip().lower()}
@@ -176,19 +172,15 @@ class RapidshareCom(Hoster):
def freeWait(self):
"""downloads html with the important information
"""
- #self.html = self.load("http://rapidshare.com/files/%s/%s" % (self.id, self.name),ref=False)
-
- #sleep(1)
-
self.no_download = True
id = self.id
name = self.name
- prepare = "http://api.rapidshare.com/cgi-bin/rsapi.cgi?sub=download_v1&fileid=%(id)s&filename=%(name)s&try=1&cbf=RSAPIDispatcher&cbid=1" % {"name": name, "id" : id}
+ prepare = "https://api.rapidshare.com/cgi-bin/rsapi.cgi?sub=download&fileid=%(id)s&filename=%(name)s&try=1&cbf=RSAPIDispatcher&cbid=1" % {"name": name, "id" : id}
+ self.log.debug("RS API Request: %s" % prepare)
result = self.load(prepare, ref=False)
-
self.log.debug("RS API Result: %s" % result)
between_wait = re.search("You need to wait (\d+) seconds", result)