# -*- coding: utf-8 -*-
"""
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License,
or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, see .
"""
from urlparse import urljoin
import re
from module.common.json_layer import json_loads
from module.plugins.Crypter import Crypter
from module.utils import save_join
class DailymotionBatch(Crypter):
__name__ = "DailymotionBatch"
__type__ = "crypter"
__pattern__ = r'https?://(?:www\.)?dailymotion\.com/((playlists/)?(?Pplaylist|user)/)?(?P[\w^_]+)(?(TYPE)|#)'
__version__ = "0.01"
__description__ = """Dailymotion.com channel & playlist decrypter"""
__author_name__ = "Walter Purcaro"
__author_mail__ = "vuolter@gmail.com"
def api_response(self, ref, req=None):
url = urljoin("https://api.dailymotion.com/", ref)
page = self.load(url, get=req)
return json_loads(page)
def getPlaylistInfo(self, id):
ref = "playlist/" + id
req = {"fields": "name,owner.screenname"}
playlist = self.api_response(ref, req)
if "error" in playlist:
return
name = playlist['name']
owner = playlist['owner.screenname']
return name, owner
def _getPlaylists(self, user_id, page=1):
ref = "user/%s/playlists" % user_id
req = {"fields": "id", "page": page, "limit": 100}
user = self.api_response(ref, req)
if "error" in user:
return
for playlist in user['list']:
yield playlist['id']
if user['has_more']:
for item in self._getPlaylists(user_id, page + 1):
yield item
def getPlaylists(self, user_id):
return [(id,) + self.getPlaylistInfo(id) for id in self._getPlaylists(user_id)]
def _getVideos(self, id, page=1):
ref = "playlist/%s/videos" % id
req = {"fields": "url", "page": page, "limit": 100}
playlist = self.api_response(ref, req)
if "error" in playlist:
return
for video in playlist['list']:
yield video['url']
if playlist['has_more']:
for item in self._getVideos(id, page + 1):
yield item
def getVideos(self, playlist_id):
return list(self._getVideos(playlist_id))[::-1]
def decrypt(self, pyfile):
m = re.match(self.__pattern__, pyfile.url)
m_id = m.group("ID")
m_type = m.group("TYPE")
if m_type == "playlist":
self.logDebug("Url recognized as Playlist")
p_info = self.getPlaylistInfo(m_id)
playlists = [(m_id,) + p_info] if p_info else None
else:
self.logDebug("Url recognized as Channel")
playlists = self.getPlaylists(m_id)
self.logDebug("%s playlist\s found on channel \"%s\"" % (len(playlists), m_id))
if not playlists:
self.fail("No playlist available")
for p_id, p_name, p_owner in playlists:
p_videos = self.getVideos(p_id)
p_folder = save_join(self.config['general']['download_folder'], p_owner, p_name)
self.logDebug("%s video\s found on playlist \"%s\"" % (len(p_videos), p_name))
self.packages.append((p_name, p_videos, p_folder)) #: folder is NOT recognized by pyload 0.4.9!