diff options
| author | Filippo Valsorda <filippo.valsorda@gmail.com> | 2014-07-10 04:10:02 +0200 | 
|---|---|---|
| committer | Filippo Valsorda <filippo.valsorda@gmail.com> | 2014-07-13 00:47:20 +0200 | 
| commit | 36cb99f95843aebac873c5f5281d3cd95f76dd01 (patch) | |
| tree | 36206437ef060902d589401ade11c2c409c05490 | |
| parent | 81650f95e2d28f4acc8a864c5221f1e95f75adda (diff) | |
[ReverbNation] Add new IE - closes #2250
| -rw-r--r-- | youtube_dl/extractor/__init__.py | 1 | ||||
| -rw-r--r-- | youtube_dl/extractor/reverbnation.py | 45 | ||||
| -rw-r--r-- | youtube_dl/utils.py | 2 | 
3 files changed, 47 insertions, 1 deletions
| diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index e89a83e32..a03f9d3ad 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -232,6 +232,7 @@ from .radiofrance import RadioFranceIE  from .rai import RaiIE  from .rbmaradio import RBMARadioIE  from .redtube import RedTubeIE +from .reverbnation import ReverbNationIE  from .ringtv import RingTVIE  from .ro220 import Ro220IE  from .rottentomatoes import RottenTomatoesIE diff --git a/youtube_dl/extractor/reverbnation.py b/youtube_dl/extractor/reverbnation.py new file mode 100644 index 000000000..49cf427a1 --- /dev/null +++ b/youtube_dl/extractor/reverbnation.py @@ -0,0 +1,45 @@ +from __future__ import unicode_literals + +import re +import time + +from .common import InfoExtractor +from ..utils import strip_jsonp + + +class ReverbNationIE(InfoExtractor): +    _VALID_URL = r'^https?://(?:www\.)?reverbnation\.com/.*?/song/(?P<id>\d+).*?$' +    _TESTS = [{ +        'url': 'http://www.reverbnation.com/alkilados/song/16965047-mona-lisa', +        'file': '16965047.mp3', +        'md5': '3da12ebca28c67c111a7f8b262d3f7a7', +        'info_dict': { +            "title": "MONA LISA", +            "uploader": "ALKILADOS", +            "uploader_id": 216429, +            "thumbnail": "//gp1.wac.edgecastcdn.net/802892/production_public/Photo/13761700/image/1366002176_AVATAR_MONA_LISA.jpg" +        }, +    }] + +    def _real_extract(self, url): +        mobj = re.match(self._VALID_URL, url) +        song_id = mobj.group('id') + +        api_res = self._download_json( +            'https://api.reverbnation.com/song/%s?callback=api_response_5&_=%d' +                % (song_id, int(time.time() * 1000)), +            song_id, +            transform_source=strip_jsonp, +            note='Downloading information of song %s' % song_id +        ) + +        return { +            'id': song_id, +            'title': api_res.get('name'), +            'url': api_res.get('url'), +            'uploader': api_res.get('artist', {}).get('name'), +            'uploader_id': api_res.get('artist', {}).get('id'), +            'thumbnail': api_res.get('image', api_res.get('thumbnail')), +            'ext': 'mp3', +            'vcodec': 'none', +        } diff --git a/youtube_dl/utils.py b/youtube_dl/utils.py index 2cba2bfc1..a2890b764 100644 --- a/youtube_dl/utils.py +++ b/youtube_dl/utils.py @@ -1428,7 +1428,7 @@ US_RATINGS = {  def strip_jsonp(code): -    return re.sub(r'(?s)^[a-zA-Z_]+\s*\(\s*(.*)\);\s*?\s*$', r'\1', code) +    return re.sub(r'(?s)^[a-zA-Z0-9_]+\s*\(\s*(.*)\)\s*?\s*$', r'\1', code)  def qualities(quality_ids): | 
