2015-01-04 13:33:26 +01:00
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
import re
from . common import InfoExtractor
2015-01-05 18:13:19 +01:00
from . . utils import parse_duration
2015-01-04 13:33:26 +01:00
class RadioBremenIE ( InfoExtractor ) :
2015-01-05 18:13:19 +01:00
_VALID_URL = r ' http?://(?:www \ .)?radiobremen \ .de/mediathek/(?:index \ .html)? \ ?id=(?P<id>[0-9]+) '
2015-01-04 13:33:26 +01:00
IE_NAME = ' radiobremen '
_TEST = {
' url ' : ' http://www.radiobremen.de/mediathek/index.html?id=114720 ' ,
' info_dict ' : {
' id ' : ' 114720 ' ,
' ext ' : ' mp4 ' ,
2015-01-05 18:13:19 +01:00
' duration ' : 1685 ,
2015-01-04 13:33:26 +01:00
' width ' : 512 ,
' title ' : ' buten un binnen vom 22. Dezember ' ,
2015-01-05 18:14:09 +01:00
' thumbnail ' : ' re:https?://.* \ .jpg$ ' ,
2015-01-04 13:33:26 +01:00
' description ' : ' Unter anderem mit diesen Themen: 45 Flüchtlinge sind in Worpswede angekommen +++ Freies Internet für alle: Bremer arbeiten an einem flächendeckenden W-Lan-Netzwerk +++ Aktivisten kämpfen für das Unibad +++ So war das Wetter 2014 +++ ' ,
} ,
}
def _real_extract ( self , url ) :
2015-01-05 18:13:19 +01:00
video_id = self . _match_id ( url )
2015-01-04 13:33:26 +01:00
2016-02-14 10:37:17 +01:00
meta_url = ' http://www.radiobremen.de/apps/php/mediathek/metadaten.php?id= %s ' % video_id
2015-01-05 18:17:03 +01:00
meta_doc = self . _download_webpage (
meta_url , video_id , ' Downloading metadata ' )
title = self . _html_search_regex (
2016-02-14 10:37:17 +01:00
r ' <h1.*>(?P<title>.+)</h1> ' , meta_doc , ' title ' )
2015-01-05 18:17:03 +01:00
description = self . _html_search_regex (
2016-02-14 10:37:17 +01:00
r ' <p>(?P<description>.*)</p> ' , meta_doc , ' description ' , fatal = False )
2015-01-05 18:17:03 +01:00
duration = parse_duration ( self . _html_search_regex (
2016-02-14 10:37:17 +01:00
r ' Länge:</td> \ s+<td>(?P<duration>[0-9]+:[0-9]+)</td> ' ,
meta_doc , ' duration ' , fatal = False ) )
2015-01-05 18:17:03 +01:00
page_doc = self . _download_webpage (
url , video_id , ' Downloading video information ' )
mobj = re . search (
r " ardformatplayerclassic \ ( \ ' playerbereich \ ' , \ ' (?P<width>[0-9]+) \ ' , \ ' .* \ ' , \ ' (?P<video_id>[0-9]+) \ ' , \ ' (?P<secret>[0-9]+) \ ' , \ ' (?P<thumbnail>.+) \ ' , \ ' \ ' \ ) " ,
page_doc )
2015-01-05 18:13:19 +01:00
video_url = (
" http://dl-ondemand.radiobremen.de/mediabase/ %s / %s _ %s _ %s .mp4 " %
( video_id , video_id , mobj . group ( " secret " ) , mobj . group ( ' width ' ) ) )
2015-01-04 13:33:26 +01:00
2015-01-05 18:13:19 +01:00
formats = [ {
' url ' : video_url ,
' ext ' : ' mp4 ' ,
2016-02-14 10:37:17 +01:00
' width ' : int ( mobj . group ( ' width ' ) ) ,
2015-01-05 18:13:19 +01:00
} ]
2015-01-04 13:33:26 +01:00
return {
' id ' : video_id ,
' title ' : title ,
' description ' : description ,
' duration ' : duration ,
2015-01-05 18:13:19 +01:00
' formats ' : formats ,
' thumbnail ' : mobj . group ( ' thumbnail ' ) ,
2015-01-04 13:33:26 +01:00
}