From f0da3f1ef925ce8aa0850277a03d510a29c0f43d Mon Sep 17 00:00:00 2001 From: phaer Date: Fri, 28 Mar 2014 17:57:25 +0200 Subject: [PATCH] [oe1] Add support for oe1.orf.at. --- youtube_dl/extractor/__init__.py | 1 + youtube_dl/extractor/oe1.py | 38 ++++++++++++++++++++++++++++++++ 2 files changed, 39 insertions(+) create mode 100644 youtube_dl/extractor/oe1.py diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index 4812962318..0e4b2b6e8c 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -177,6 +177,7 @@ from .normalboots import NormalbootsIE from .novamov import NovaMovIE from .nowness import NownessIE from .nowvideo import NowVideoIE +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 + }