diff options
Diffstat (limited to 'module/plugins/crypter/DailymotionBatch.py')
| -rw-r--r-- | module/plugins/crypter/DailymotionBatch.py | 111 | 
1 files changed, 0 insertions, 111 deletions
| diff --git a/module/plugins/crypter/DailymotionBatch.py b/module/plugins/crypter/DailymotionBatch.py deleted file mode 100644 index 5c0dd9cec..000000000 --- a/module/plugins/crypter/DailymotionBatch.py +++ /dev/null @@ -1,111 +0,0 @@ -# -*- 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 <http://www.gnu.org/licenses/>. - -    @author: Walter Purcaro -""" - -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/)?(?P<TYPE>playlist|user)/)?(?P<ID>[\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! | 
