diff options
| -rw-r--r-- | README.md | 21 | ||||
| -rw-r--r-- | test/test_download.py | 2 | ||||
| -rw-r--r-- | test/test_playlists.py | 10 | ||||
| -rw-r--r-- | youtube_dl/extractor/__init__.py | 1 | ||||
| -rw-r--r-- | youtube_dl/extractor/everyonesmixtape.py | 69 | ||||
| -rw-r--r-- | youtube_dl/extractor/generic.py | 2 | ||||
| -rw-r--r-- | youtube_dl/extractor/redtube.py | 2 | ||||
| -rw-r--r-- | youtube_dl/extractor/youtube.py | 2 | ||||
| -rw-r--r-- | youtube_dl/version.py | 2 | 
9 files changed, 96 insertions, 15 deletions
| @@ -93,13 +93,13 @@ which means you can modify it, redistribute it or use it however you like.                                 different, %(autonumber)s to get an automatically                                 incremented number, %(ext)s for the filename                                 extension, %(format)s for the format description -                               (like "22 - 1280x720" or "HD"),%(format_id)s for +                               (like "22 - 1280x720" or "HD"), %(format_id)s for                                 the unique id of the format (like Youtube's -                               itags: "137"),%(upload_date)s for the upload date -                               (YYYYMMDD), %(extractor)s for the provider -                               (youtube, metacafe, etc), %(id)s for the video id -                               , %(playlist)s for the playlist the video is in, -                               %(playlist_index)s for the position in the +                               itags: "137"), %(upload_date)s for the upload +                               date (YYYYMMDD), %(extractor)s for the provider +                               (youtube, metacafe, etc), %(id)s for the video +                               id, %(playlist)s for the playlist the video is +                               in, %(playlist_index)s for the position in the                                 playlist and %% for a literal percent. Use - to                                 output to stdout. Can also be used to download to                                 a different directory, for example with -o '/my/d @@ -111,7 +111,7 @@ which means you can modify it, redistribute it or use it however you like.                                 avoid "&" and spaces in filenames      -a, --batch-file FILE      file containing URLs to download ('-' for stdin)      --load-info FILE           json file containing the video information -                               (created with the "--write-json" option +                               (created with the "--write-json" option)      -w, --no-overwrites        do not overwrite files      -c, --continue             force resume of partially downloaded files. By                                 default, youtube-dl will resume downloads if @@ -145,7 +145,7 @@ which means you can modify it, redistribute it or use it however you like.      --no-progress              do not print progress bar      --console-title            display progress in console titlebar      -v, --verbose              print various debugging information -    --dump-intermediate-pages  print downloaded pages to debug problems(very +    --dump-intermediate-pages  print downloaded pages to debug problems (very                                 verbose)      --write-pages              Write downloaded intermediary pages to files in                                 the current directory to debug problems @@ -158,8 +158,7 @@ which means you can modify it, redistribute it or use it however you like.      --prefer-free-formats      prefer free video formats unless a specific one                                 is requested      --max-quality FORMAT       highest quality format to download -    -F, --list-formats         list all available formats (currently youtube -                               only) +    -F, --list-formats         list all available formats  ## Subtitle Options:      --write-sub                write subtitle file @@ -177,7 +176,7 @@ which means you can modify it, redistribute it or use it however you like.      -u, --username USERNAME    account username      -p, --password PASSWORD    account password      -n, --netrc                use .netrc authentication data -    --video-password PASSWORD  video password (vimeo only) +    --video-password PASSWORD  video password (vimeo, smotri)  ## Post-processing Options:      -x, --extract-audio        convert video files to audio-only files (requires diff --git a/test/test_download.py b/test/test_download.py index d0be8d27c..0d925ae69 100644 --- a/test/test_download.py +++ b/test/test_download.py @@ -148,7 +148,7 @@ def generator(test_case):                      for key, value in info_dict.items()                      if value and key in ('title', 'description', 'uploader', 'upload_date', 'uploader_id', 'location'))                  if not all(key in tc.get('info_dict', {}).keys() for key in test_info_dict.keys()): -                    sys.stderr.write(u'\n"info_dict": ' + json.dumps(test_info_dict, ensure_ascii=False, indent=2) + u'\n') +                    sys.stderr.write(u'\n"info_dict": ' + json.dumps(test_info_dict, ensure_ascii=False, indent=4) + u'\n')                  # Check for the presence of mandatory fields                  for key in ('id', 'url', 'title', 'ext'): diff --git a/test/test_playlists.py b/test/test_playlists.py index b3bfbd923..5eeba091e 100644 --- a/test/test_playlists.py +++ b/test/test_playlists.py @@ -32,6 +32,7 @@ from youtube_dl.extractor import (      IviCompilationIE,      ImdbListIE,      KhanAcademyIE, +    EveryonesMixtapeIE,  ) @@ -210,6 +211,15 @@ class TestPlaylists(unittest.TestCase):          self.assertEqual(result['description'], 'How have humans protected their secret messages through history? What has changed today?')          self.assertTrue(len(result['entries']) >= 3) +    def test_EveryonesMixtape(self): +        dl = FakeYDL() +        ie = EveryonesMixtapeIE(dl) +        result = ie.extract('http://everyonesmixtape.com/#/mix/m7m0jJAbMQi') +        self.assertIsPlaylist(result) +        self.assertEqual(result['id'], 'm7m0jJAbMQi') +        self.assertEqual(result['title'], 'Driving') +        self.assertEqual(len(result['entries']), 24) +  if __name__ == '__main__':      unittest.main() diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index 209f327ec..d66f7b026 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -52,6 +52,7 @@ from .ehow import EHowIE  from .eighttracks import EightTracksIE  from .eitb import EitbIE  from .escapist import EscapistIE +from .everyonesmixtape import EveryonesMixtapeIE  from .exfm import ExfmIE  from .extremetube import ExtremeTubeIE  from .facebook import FacebookIE diff --git a/youtube_dl/extractor/everyonesmixtape.py b/youtube_dl/extractor/everyonesmixtape.py new file mode 100644 index 000000000..12829cbcc --- /dev/null +++ b/youtube_dl/extractor/everyonesmixtape.py @@ -0,0 +1,69 @@ +from __future__ import unicode_literals + +import re + +from .common import InfoExtractor +from ..utils import ( +    compat_urllib_request, +    ExtractorError, +) + + +class EveryonesMixtapeIE(InfoExtractor): +    _VALID_URL = r'https?://(?:www\.)?everyonesmixtape\.com/#/mix/(?P<id>[0-9a-zA-Z]+)(?:/(?P<songnr>[0-9]))?$' + +    _TEST = { +        'url': 'http://everyonesmixtape.com/#/mix/m7m0jJAbMQi/5', +        'file': '5bfseWNmlds.mp4', +        "info_dict": { +            "title": "Passion Pit - \"Sleepyhead\" (Official Music Video)", +            "uploader": "FKR.TV", +            "uploader_id": "frenchkissrecords", +            "description": "Music video for \"Sleepyhead\" from Passion Pit's debut EP Chunk Of Change.\nBuy on iTunes: https://itunes.apple.com/us/album/chunk-of-change-ep/id300087641\n\nDirected by The Wilderness.\n\nhttp://www.passionpitmusic.com\nhttp://www.frenchkissrecords.com", +            "upload_date": "20081015" +        }, +        'params': { +            'skip_download': True,  # This is simply YouTube +        } +    } + +    def _real_extract(self, url): +        mobj = re.match(self._VALID_URL, url) +        playlist_id = mobj.group('id') + +        pllist_url = 'http://everyonesmixtape.com/mixtape.php?a=getMixes&u=-1&linked=%s&explore=' % playlist_id +        pllist_req = compat_urllib_request.Request(pllist_url) +        pllist_req.add_header('X-Requested-With', 'XMLHttpRequest') + +        playlist_list = self._download_json( +            pllist_req, playlist_id, note='Downloading playlist metadata') +        try: +            playlist_no = next(playlist['id'] +                               for playlist in playlist_list +                               if playlist['code'] == playlist_id) +        except StopIteration: +            raise ExtractorError('Playlist id not found') + +        pl_url = 'http://everyonesmixtape.com/mixtape.php?a=getMix&id=%s&userId=null&code=' % playlist_no +        pl_req = compat_urllib_request.Request(pl_url) +        pl_req.add_header('X-Requested-With', 'XMLHttpRequest') +        playlist = self._download_json( +            pl_req, playlist_id, note='Downloading playlist info') + +        entries = [{ +            '_type': 'url', +            'url': t['url'], +            'title': t['title'], +        } for t in playlist['tracks']] + +        if mobj.group('songnr'): +            songnr = int(mobj.group('songnr')) - 1 +            return entries[songnr] + +        playlist_title = playlist['mixData']['name'] +        return { +            '_type': 'playlist', +            'id': playlist_id, +            'title': playlist_title, +            'entries': entries, +        } diff --git a/youtube_dl/extractor/generic.py b/youtube_dl/extractor/generic.py index a9023f38d..839530982 100644 --- a/youtube_dl/extractor/generic.py +++ b/youtube_dl/extractor/generic.py @@ -328,7 +328,7 @@ class GenericIE(InfoExtractor):              mobj = re.search(r'[^A-Za-z0-9]?(?:file|source)=(http[^\'"&]*)', webpage)          if mobj is None:              # Broaden the search a little bit: JWPlayer JS loader -            mobj = re.search(r'[^A-Za-z0-9]?file["\']?:\s*["\'](http[^\'"]*)', webpage) +            mobj = re.search(r'[^A-Za-z0-9]?file["\']?:\s*["\'](http(?![^\'"]+\.[0-9]+[\'"])[^\'"]+)["\']', webpage)          if mobj is None:              # Try to find twitter cards info              mobj = re.search(r'<meta (?:property|name)="twitter:player:stream" (?:content|value)="(.+?)"', webpage) diff --git a/youtube_dl/extractor/redtube.py b/youtube_dl/extractor/redtube.py index c2254ae8a..5c4cd2068 100644 --- a/youtube_dl/extractor/redtube.py +++ b/youtube_dl/extractor/redtube.py @@ -4,7 +4,7 @@ from .common import InfoExtractor  class RedTubeIE(InfoExtractor): -    _VALID_URL = r'(?:http://)?(?:www\.)?redtube\.com/(?P<id>[0-9]+)' +    _VALID_URL = r'http://(?:www\.)?redtube\.com/(?P<id>[0-9]+)'      _TEST = {          u'url': u'http://www.redtube.com/66418',          u'file': u'66418.mp4', diff --git a/youtube_dl/extractor/youtube.py b/youtube_dl/extractor/youtube.py index 28c88ffc7..bf3fde610 100644 --- a/youtube_dl/extractor/youtube.py +++ b/youtube_dl/extractor/youtube.py @@ -131,6 +131,8 @@ class YoutubeIE(YoutubeBaseInfoExtractor, SubtitlesInfoExtractor):                       (                           (?:https?://|//)?                                    # http(s):// or protocol-independent URL (optional)                           (?:(?:(?:(?:\w+\.)?[yY][oO][uU][tT][uU][bB][eE](?:-nocookie)?\.com/| +                            (?:www\.)?deturl\.com/www\.youtube\.com/| +                            (?:www\.)?pwnyoutube\.com|                              tube\.majestyc\.net/|                              youtube\.googleapis\.com/)                        # the various hostnames, with wildcard subdomains                           (?:.*?\#/)?                                          # handle anchor (#/) redirect urls diff --git a/youtube_dl/version.py b/youtube_dl/version.py index d1233be65..33abf1ae3 100644 --- a/youtube_dl/version.py +++ b/youtube_dl/version.py @@ -1,2 +1,2 @@ -__version__ = '2014.01.08' +__version__ = '2013.01.17.1' | 
