diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index eef13d2b8f..8e81fa6193 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -178,6 +178,7 @@ from .nowness import NownessIE from .nowvideo import NowVideoIE from .ntv import NTVIE +from .oe1 import OE1IE from .ooyala import OoyalaIE from .orf import ORFIE from .parliamentliveuk import ParliamentLiveUKIE diff --git a/youtube_dl/extractor/oe1.py b/youtube_dl/extractor/oe1.py new file mode 100644 index 0000000000..f327e9e086 --- /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\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 + }