summaryrefslogtreecommitdiffstats
path: root/module/plugins/hoster
diff options
context:
space:
mode:
Diffstat (limited to 'module/plugins/hoster')
-rw-r--r--module/plugins/hoster/Keep2ShareCc.py20
-rw-r--r--module/plugins/hoster/RyushareCom.py2
-rw-r--r--module/plugins/hoster/UpleaCom.py12
3 files changed, 24 insertions, 10 deletions
diff --git a/module/plugins/hoster/Keep2ShareCc.py b/module/plugins/hoster/Keep2ShareCc.py
index c927ea11c..1dba9713a 100644
--- a/module/plugins/hoster/Keep2ShareCc.py
+++ b/module/plugins/hoster/Keep2ShareCc.py
@@ -11,7 +11,7 @@ class Keep2ShareCc(SimpleHoster):
__name__ = "Keep2ShareCc"
__type__ = "hoster"
__version__ = "0.28"
- __status__ = "broken"
+ __status__ = "testing"
__pattern__ = r'https?://(?:www\.)?(keep2share|k2s|keep2s)\.cc/file/(?P<ID>\w+)'
__config__ = [("activated" , "bool", "Activated" , True),
@@ -34,8 +34,9 @@ class Keep2ShareCc(SimpleHoster):
OFFLINE_PATTERN = r'File not found or deleted|Sorry, this file is blocked or deleted|Error 404'
TEMP_OFFLINE_PATTERN = r'Downloading blocked due to'
- LINK_FREE_PATTERN = r'"(.+?url.html\?file=.+?)"|window\.location\.href = \'(.+?)\';'
+ LINK_FREE_PATTERN = r'"([^"]+?url.html\?file=.+?)"|window\.location\.href = \'(.+?)\';'
LINK_PREMIUM_PATTERN = r'window\.location\.href = \'(.+?)\';'
+ UNIQUE_ID_PATTERN = r"data: {uniqueId: '(?P<uID>\w+)', free: 1}"
CAPTCHA_PATTERN = r'src="(/file/captcha\.html.+?)"'
@@ -68,6 +69,7 @@ class Keep2ShareCc(SimpleHoster):
self.retry(wait=wait_time, msg="Please wait to download this file")
self.info.pop('error', None)
+ # super(Keep2ShareCc, self).check_errors()
def handle_free(self, pyfile):
@@ -83,13 +85,22 @@ class Keep2ShareCc(SimpleHoster):
if m is None:
self.handle_captcha()
self.wait(31)
- self.data = self.load(pyfile.url)
+ # get the uniqueId from the html code
+ m = re.search(self.UNIQUE_ID_PATTERN, self.data)
+ if m is None:
+ self.error(_("Unique-ID pattern not found"))
+ self.data = self.load(pyfile.url, post={'uniqueId': m.group('uID'), 'free': '1'})
m = re.search(self.LINK_FREE_PATTERN, self.data)
if m is None:
self.error(_("Free download link not found"))
- self.link = m.group(1)
+ # if group 1 did not match, check group 2
+ if m.group(1) is not None:
+ self.link = m.group(1)
+ else:
+ self.link = m.group(2)
+ self.log_debug("download link: %s" % self.link)
def handle_captcha(self):
@@ -121,3 +132,4 @@ class Keep2ShareCc(SimpleHoster):
getInfo = create_getInfo(Keep2ShareCc)
+
diff --git a/module/plugins/hoster/RyushareCom.py b/module/plugins/hoster/RyushareCom.py
index 79822877d..392b18348 100644
--- a/module/plugins/hoster/RyushareCom.py
+++ b/module/plugins/hoster/RyushareCom.py
@@ -6,7 +6,7 @@ from module.plugins.internal.DeadHoster import DeadHoster, create_getInfo
class RyushareCom(DeadHoster):
__name__ = "RyushareCom"
__type__ = "hoster"
- __version__ = "0.17"
+ __version__ = "0.30"
__status__ = "stable"
__pattern__ = r'http://(?:www\.)?ryushare\.com/\w+'
diff --git a/module/plugins/hoster/UpleaCom.py b/module/plugins/hoster/UpleaCom.py
index d1656556b..c552adc0f 100644
--- a/module/plugins/hoster/UpleaCom.py
+++ b/module/plugins/hoster/UpleaCom.py
@@ -9,7 +9,7 @@ from module.plugins.internal.XFSHoster import XFSHoster, create_getInfo
class UpleaCom(XFSHoster):
__name__ = "UpleaCom"
__type__ = "hoster"
- __version__ = "0.15"
+ __version__ = "0.16"
__status__ = "testing"
__pattern__ = r'https?://(?:www\.)?uplea\.com/dl/\w{15}'
@@ -36,7 +36,7 @@ class UpleaCom(XFSHoster):
LINK_PATTERN = r'"(https?://\w+\.uplea\.com/anonym/.*?)"'
PREMIUM_ONLY_PATTERN = r'You need to have a Premium subscription to download this file'
- WAIT_PATTERN = r'timeText: ?([\d.]+),'
+ WAIT_PATTERN = r'timeText: ?(\d+),'
STEP_PATTERN = r'<a href="(/step/.+)">'
@@ -54,8 +54,7 @@ class UpleaCom(XFSHoster):
self.data = self.load(urlparse.urljoin("http://uplea.com/", m.group(1)))
m = re.search(self.WAIT_PATTERN, self.data)
- if m is not None:
- self.log_debug("Waiting %s seconds" % m.group(1))
+ if m:
self.wait(m.group(1), True)
self.retry()
@@ -64,7 +63,10 @@ class UpleaCom(XFSHoster):
self.error(_("LINK_PATTERN not found"))
self.link = m.group(1)
- self.wait(15)
+
+ m = re.search(r".ulCounter\({'timer':(\d+)}\)", self.data)
+ if m:
+ self.wait(m.group(1))
getInfo = create_getInfo(UpleaCom)