summaryrefslogtreecommitdiffstats
path: root/module
diff options
context:
space:
mode:
authorGravatar spoob <spoob@gmx.de> 2010-01-13 14:21:13 +0100
committerGravatar spoob <spoob@gmx.de> 2010-01-13 14:21:13 +0100
commitb1637236297fc5c3278e4d358fa7ec990824db71 (patch)
tree0d3e31a8c8fdb304ac3dab26687de4e443e5890a /module
parentforgot changes (diff)
downloadpyload-b1637236297fc5c3278e4d358fa7ec990824db71.tar.xz
More YoutubeChannel Options
Diffstat (limited to 'module')
-rw-r--r--module/config/plugin_default.xml1
-rw-r--r--module/plugins/decrypter/YoutubeChannel.py31
2 files changed, 19 insertions, 13 deletions
diff --git a/module/config/plugin_default.xml b/module/config/plugin_default.xml
index 773e4e46f..43c220516 100644
--- a/module/config/plugin_default.xml
+++ b/module/config/plugin_default.xml
@@ -27,6 +27,7 @@
<YoutubeChannel>
<!-- False for no limitation -->
<max_videos>False</max_videos>
+ <video_groups name="Video Groups" type="str" input="uploads;favorites">uploads,favorites</video_groups>
</YoutubeChannel>
<SerienjunkiesOrg>
<preferredHoster>RapidshareCom,UploadedTo,NetloadIn,FilefactoryCom</preferredHoster>
diff --git a/module/plugins/decrypter/YoutubeChannel.py b/module/plugins/decrypter/YoutubeChannel.py
index 27a4ff8a7..2a3ae337f 100644
--- a/module/plugins/decrypter/YoutubeChannel.py
+++ b/module/plugins/decrypter/YoutubeChannel.py
@@ -13,7 +13,7 @@ class YoutubeChannel(Plugin):
props['name'] = "YoutubeChannel"
props['type'] = "container"
props['pattern'] = r"http://(www\.)?(de\.)?\youtube\.com/user/*"
- props['version'] = "0.3"
+ props['version'] = "0.4"
props['description'] = """Youtube.com Channel Download Plugin"""
props['author_name'] = ("RaNaN", "Spoob")
props['author_mail'] = ("RaNaN@pyload.org", "spoob@pyload.org")
@@ -34,16 +34,21 @@ class YoutubeChannel(Plugin):
max_videos = 1000 #max video a user can upload
page = 0
temp_links = []
- for start_index in range(1, int(max_videos), 50):
- max_results = max_videos - page * 50
- if max_results > 50:
- max_results = 50
- url = "http://gdata.youtube.com/feeds/api/users/" + self.user + "/uploads?max-results=" + str(max_results) + "&start-index=" + str(start_index)
- rep = self.req.load(url)
- new_links = re.findall(r"href\='(http:\/\/www.youtube.com\/watch\?v\=[^']+)", rep)
- if new_links != []:
- temp_links.extend(new_links)
- else:
- break
- page += 1
+ if "," in self.config['video_groups']:
+ video_groups = self.config['video_groups'].split(",")
+ else:
+ video_groups = [self.config['video_groups']]
+ for group in video_groups:
+ for start_index in range(1, int(max_videos), 50):
+ max_results = max_videos - page * 50
+ if max_results > 50:
+ max_results = 50
+ url = "http://gdata.youtube.com/feeds/api/users/%s/%s?max-results=%i&start-index=%i" % (self.user, group, max_results, start_index)
+ rep = self.req.load(str(url))
+ new_links = re.findall(r"href\='(http:\/\/www.youtube.com\/watch\?v\=[^']+)", rep)
+ if new_links != []:
+ temp_links.extend(new_links)
+ else:
+ break
+ page += 1
self.links = temp_links