about summary refs log tree commit diff
path: root/youtube_dl/extractor/radiode.py
diff options
context:
space:
mode:
authorSergey M․ <dstftw@gmail.com>2014-12-06 23:01:52 +0600
committerSergey M․ <dstftw@gmail.com>2014-12-06 23:01:52 +0600
commit6d0886204a920e64606688b1217835d10e47d281 (patch)
treea6a2376150e52284923d53581b6d377e03cfbfe7 /youtube_dl/extractor/radiode.py
parent04d02a9d57c834d3044871ce7dcc90932e686e46 (diff)
downloadyoutube-dl-6d0886204a920e64606688b1217835d10e47d281.tar.gz
youtube-dl-6d0886204a920e64606688b1217835d10e47d281.tar.xz
youtube-dl-6d0886204a920e64606688b1217835d10e47d281.zip
[radio.de] Add support for radio.de websites (Closes #4393)
Diffstat (limited to 'youtube_dl/extractor/radiode.py')
-rw-r--r--youtube_dl/extractor/radiode.py55
1 files changed, 55 insertions, 0 deletions
diff --git a/youtube_dl/extractor/radiode.py b/youtube_dl/extractor/radiode.py
new file mode 100644
index 000000000..f95bc9454
--- /dev/null
+++ b/youtube_dl/extractor/radiode.py
@@ -0,0 +1,55 @@
+from __future__ import unicode_literals
+
+import json
+
+from .common import InfoExtractor
+
+
+class RadioDeIE(InfoExtractor):
+    IE_NAME = 'radio.de'
+    _VALID_URL = r'https?://(?P<id>.+?)\.(?:radio\.(?:de|at|fr|pt|es|pl|it)|rad\.io)'
+    _TEST = {
+        'url': 'http://ndr2.radio.de/',
+        'md5': '3b4cdd011bc59174596b6145cda474a4',
+        'info_dict': {
+            'id': 'ndr2',
+            'ext': 'mp3',
+            'title': 're:^NDR 2 [0-9]{4}-[0-9]{2}-[0-9]{2} [0-9]{2}:[0-9]{2}$',
+            'description': 'md5:591c49c702db1a33751625ebfb67f273',
+            'thumbnail': 're:^https?://.*\.png',
+        },
+        'params': {
+            'skip_download': True,
+        }
+    }
+
+    def _real_extract(self, url):
+        radio_id = self._match_id(url)
+
+        webpage = self._download_webpage(url, radio_id)
+
+        broadcast = json.loads(self._search_regex(
+            r'_getBroadcast\s*=\s*function\(\s*\)\s*{\s*return\s+({.+?})\s*;\s*}',
+            webpage, 'broadcast'))
+
+        title = self._live_title(broadcast['name'])
+        description = broadcast.get('description') or broadcast.get('shortDescription')
+        thumbnail = broadcast.get('picture4Url') or broadcast.get('picture4TransUrl')
+
+        formats = [{
+            'url': stream['streamUrl'],
+            'ext': stream['streamContentFormat'].lower(),
+            'acodec': stream['streamContentFormat'],
+            'abr': stream['bitRate'],
+            'asr': stream['sampleRate']
+        } for stream in broadcast['streamUrls']]
+        self._sort_formats(formats)
+
+        return {
+            'id': radio_id,
+            'title': title,
+            'description': description,
+            'thumbnail': thumbnail,
+            'is_live': True,
+            'formats': formats,
+        }