diff options
author | Philipp Hagemeister <phihag@phihag.de> | 2014-03-28 23:21:58 +0100 |
---|---|---|
committer | Philipp Hagemeister <phihag@phihag.de> | 2014-03-28 23:21:58 +0100 |
commit | e9a6fd6a68024b7835d4ee664c921ef3f3591594 (patch) | |
tree | c0c0c6453e9e3d16da1554a905a0b259d7eadf4e /youtube_dl/extractor/oe1.py | |
parent | bf30f3bd9d87dad8391a05b2631116c31ed1ce77 (diff) | |
parent | f0da3f1ef925ce8aa0850277a03d510a29c0f43d (diff) |
Merge remote-tracking branch 'phaer/add-oe1-support'
Diffstat (limited to 'youtube_dl/extractor/oe1.py')
-rw-r--r-- | youtube_dl/extractor/oe1.py | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/youtube_dl/extractor/oe1.py b/youtube_dl/extractor/oe1.py new file mode 100644 index 000000000..f327e9e08 --- /dev/null +++ b/youtube_dl/extractor/oe1.py @@ -0,0 +1,38 @@ +# coding: utf-8 +from __future__ import unicode_literals +import calendar +import datetime +import json +import re + +from .common import InfoExtractor + +# audios on oe1.orf.at are only available for 7 days, so we can't +# add tests. + + +class OE1IE(InfoExtractor): + _VALID_URL = r'http://oe1\.orf\.at/programm/(?P<id>\d+)' + + def _real_extract(self, url): + mobj = re.match(self._VALID_URL, url) + show_id = mobj.group('id') + data = json.loads(self._download_webpage( + 'http://oe1.orf.at/programm/%s/konsole' % show_id, + show_id + )) + + timestamp = datetime.datetime.strptime('%s %s' % ( + data['item']['day_label'], + data['item']['time'] + ), '%d.%m.%Y %H:%M') + unix_timestamp = calendar.timegm(timestamp.utctimetuple()) + + return { + 'id': show_id, + 'title': data['item']['title'], + 'url': data['item']['url_stream'], + 'ext': 'mp3', + 'description': data['item']['info'], + 'timestamp': unix_timestamp + } |