forked from minhngoc25a/youtube-dl
[nowtv] Fix extraction (Closes #6357)
This commit is contained in:
parent
9cc93c64aa
commit
cdc682d5a4
|
@ -7,6 +7,7 @@ from .common import InfoExtractor
|
||||||
from ..compat import compat_str
|
from ..compat import compat_str
|
||||||
from ..utils import (
|
from ..utils import (
|
||||||
ExtractorError,
|
ExtractorError,
|
||||||
|
determine_ext,
|
||||||
int_or_none,
|
int_or_none,
|
||||||
parse_iso8601,
|
parse_iso8601,
|
||||||
parse_duration,
|
parse_duration,
|
||||||
|
@ -15,7 +16,7 @@ from ..utils import (
|
||||||
|
|
||||||
|
|
||||||
class NowTVIE(InfoExtractor):
|
class NowTVIE(InfoExtractor):
|
||||||
_VALID_URL = r'https?://(?:www\.)?nowtv\.de/(?P<station>rtl|rtl2|rtlnitro|superrtl|ntv|vox)/(?P<id>.+?)/player'
|
_VALID_URL = r'https?://(?:www\.)?nowtv\.de/(?:rtl|rtl2|rtlnitro|superrtl|ntv|vox)/(?P<id>.+?)/player'
|
||||||
|
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
# rtl
|
# rtl
|
||||||
|
@ -23,7 +24,7 @@ class NowTVIE(InfoExtractor):
|
||||||
'info_dict': {
|
'info_dict': {
|
||||||
'id': '203519',
|
'id': '203519',
|
||||||
'display_id': 'bauer-sucht-frau/die-neuen-bauern-und-eine-hochzeit',
|
'display_id': 'bauer-sucht-frau/die-neuen-bauern-und-eine-hochzeit',
|
||||||
'ext': 'mp4',
|
'ext': 'flv',
|
||||||
'title': 'Die neuen Bauern und eine Hochzeit',
|
'title': 'Die neuen Bauern und eine Hochzeit',
|
||||||
'description': 'md5:e234e1ed6d63cf06be5c070442612e7e',
|
'description': 'md5:e234e1ed6d63cf06be5c070442612e7e',
|
||||||
'thumbnail': 're:^https?://.*\.jpg$',
|
'thumbnail': 're:^https?://.*\.jpg$',
|
||||||
|
@ -32,7 +33,7 @@ class NowTVIE(InfoExtractor):
|
||||||
'duration': 2786,
|
'duration': 2786,
|
||||||
},
|
},
|
||||||
'params': {
|
'params': {
|
||||||
# m3u8 download
|
# rtmp download
|
||||||
'skip_download': True,
|
'skip_download': True,
|
||||||
},
|
},
|
||||||
}, {
|
}, {
|
||||||
|
@ -41,7 +42,7 @@ class NowTVIE(InfoExtractor):
|
||||||
'info_dict': {
|
'info_dict': {
|
||||||
'id': '203481',
|
'id': '203481',
|
||||||
'display_id': 'berlin-tag-nacht/berlin-tag-nacht-folge-934',
|
'display_id': 'berlin-tag-nacht/berlin-tag-nacht-folge-934',
|
||||||
'ext': 'mp4',
|
'ext': 'flv',
|
||||||
'title': 'Berlin - Tag & Nacht (Folge 934)',
|
'title': 'Berlin - Tag & Nacht (Folge 934)',
|
||||||
'description': 'md5:c85e88c2e36c552dfe63433bc9506dd0',
|
'description': 'md5:c85e88c2e36c552dfe63433bc9506dd0',
|
||||||
'thumbnail': 're:^https?://.*\.jpg$',
|
'thumbnail': 're:^https?://.*\.jpg$',
|
||||||
|
@ -50,7 +51,7 @@ class NowTVIE(InfoExtractor):
|
||||||
'duration': 2641,
|
'duration': 2641,
|
||||||
},
|
},
|
||||||
'params': {
|
'params': {
|
||||||
# m3u8 download
|
# rtmp download
|
||||||
'skip_download': True,
|
'skip_download': True,
|
||||||
},
|
},
|
||||||
}, {
|
}, {
|
||||||
|
@ -59,7 +60,7 @@ class NowTVIE(InfoExtractor):
|
||||||
'info_dict': {
|
'info_dict': {
|
||||||
'id': '165780',
|
'id': '165780',
|
||||||
'display_id': 'alarm-fuer-cobra-11-die-autobahnpolizei/hals-und-beinbruch-2014-08-23-21-10-00',
|
'display_id': 'alarm-fuer-cobra-11-die-autobahnpolizei/hals-und-beinbruch-2014-08-23-21-10-00',
|
||||||
'ext': 'mp4',
|
'ext': 'flv',
|
||||||
'title': 'Hals- und Beinbruch',
|
'title': 'Hals- und Beinbruch',
|
||||||
'description': 'md5:b50d248efffe244e6f56737f0911ca57',
|
'description': 'md5:b50d248efffe244e6f56737f0911ca57',
|
||||||
'thumbnail': 're:^https?://.*\.jpg$',
|
'thumbnail': 're:^https?://.*\.jpg$',
|
||||||
|
@ -68,7 +69,7 @@ class NowTVIE(InfoExtractor):
|
||||||
'duration': 2742,
|
'duration': 2742,
|
||||||
},
|
},
|
||||||
'params': {
|
'params': {
|
||||||
# m3u8 download
|
# rtmp download
|
||||||
'skip_download': True,
|
'skip_download': True,
|
||||||
},
|
},
|
||||||
}, {
|
}, {
|
||||||
|
@ -77,7 +78,7 @@ class NowTVIE(InfoExtractor):
|
||||||
'info_dict': {
|
'info_dict': {
|
||||||
'id': '99205',
|
'id': '99205',
|
||||||
'display_id': 'medicopter-117/angst',
|
'display_id': 'medicopter-117/angst',
|
||||||
'ext': 'mp4',
|
'ext': 'flv',
|
||||||
'title': 'Angst!',
|
'title': 'Angst!',
|
||||||
'description': 'md5:30cbc4c0b73ec98bcd73c9f2a8c17c4e',
|
'description': 'md5:30cbc4c0b73ec98bcd73c9f2a8c17c4e',
|
||||||
'thumbnail': 're:^https?://.*\.jpg$',
|
'thumbnail': 're:^https?://.*\.jpg$',
|
||||||
|
@ -86,7 +87,7 @@ class NowTVIE(InfoExtractor):
|
||||||
'duration': 3025,
|
'duration': 3025,
|
||||||
},
|
},
|
||||||
'params': {
|
'params': {
|
||||||
# m3u8 download
|
# rtmp download
|
||||||
'skip_download': True,
|
'skip_download': True,
|
||||||
},
|
},
|
||||||
}, {
|
}, {
|
||||||
|
@ -95,7 +96,7 @@ class NowTVIE(InfoExtractor):
|
||||||
'info_dict': {
|
'info_dict': {
|
||||||
'id': '203521',
|
'id': '203521',
|
||||||
'display_id': 'ratgeber-geld/thema-ua-der-erste-blick-die-apple-watch',
|
'display_id': 'ratgeber-geld/thema-ua-der-erste-blick-die-apple-watch',
|
||||||
'ext': 'mp4',
|
'ext': 'flv',
|
||||||
'title': 'Thema u.a.: Der erste Blick: Die Apple Watch',
|
'title': 'Thema u.a.: Der erste Blick: Die Apple Watch',
|
||||||
'description': 'md5:4312b6c9d839ffe7d8caf03865a531af',
|
'description': 'md5:4312b6c9d839ffe7d8caf03865a531af',
|
||||||
'thumbnail': 're:^https?://.*\.jpg$',
|
'thumbnail': 're:^https?://.*\.jpg$',
|
||||||
|
@ -104,7 +105,7 @@ class NowTVIE(InfoExtractor):
|
||||||
'duration': 1083,
|
'duration': 1083,
|
||||||
},
|
},
|
||||||
'params': {
|
'params': {
|
||||||
# m3u8 download
|
# rtmp download
|
||||||
'skip_download': True,
|
'skip_download': True,
|
||||||
},
|
},
|
||||||
}, {
|
}, {
|
||||||
|
@ -113,7 +114,7 @@ class NowTVIE(InfoExtractor):
|
||||||
'info_dict': {
|
'info_dict': {
|
||||||
'id': '128953',
|
'id': '128953',
|
||||||
'display_id': 'der-hundeprofi/buero-fall-chihuahua-joel',
|
'display_id': 'der-hundeprofi/buero-fall-chihuahua-joel',
|
||||||
'ext': 'mp4',
|
'ext': 'flv',
|
||||||
'title': "Büro-Fall / Chihuahua 'Joel'",
|
'title': "Büro-Fall / Chihuahua 'Joel'",
|
||||||
'description': 'md5:e62cb6bf7c3cc669179d4f1eb279ad8d',
|
'description': 'md5:e62cb6bf7c3cc669179d4f1eb279ad8d',
|
||||||
'thumbnail': 're:^https?://.*\.jpg$',
|
'thumbnail': 're:^https?://.*\.jpg$',
|
||||||
|
@ -122,15 +123,13 @@ class NowTVIE(InfoExtractor):
|
||||||
'duration': 3092,
|
'duration': 3092,
|
||||||
},
|
},
|
||||||
'params': {
|
'params': {
|
||||||
# m3u8 download
|
# rtmp download
|
||||||
'skip_download': True,
|
'skip_download': True,
|
||||||
},
|
},
|
||||||
}]
|
}]
|
||||||
|
|
||||||
def _real_extract(self, url):
|
def _real_extract(self, url):
|
||||||
mobj = re.match(self._VALID_URL, url)
|
display_id = self._match_id(url)
|
||||||
display_id = mobj.group('id')
|
|
||||||
station = mobj.group('station')
|
|
||||||
|
|
||||||
info = self._download_json(
|
info = self._download_json(
|
||||||
'https://api.nowtv.de/v3/movies/%s?fields=id,title,free,geoblocked,articleLong,articleShort,broadcastStartDate,seoUrl,duration,format,files' % display_id,
|
'https://api.nowtv.de/v3/movies/%s?fields=id,title,free,geoblocked,articleLong,articleShort,broadcastStartDate,seoUrl,duration,format,files' % display_id,
|
||||||
|
@ -148,29 +147,19 @@ class NowTVIE(InfoExtractor):
|
||||||
raise ExtractorError(
|
raise ExtractorError(
|
||||||
'Video %s is not available for free' % video_id, expected=True)
|
'Video %s is not available for free' % video_id, expected=True)
|
||||||
|
|
||||||
f = info.get('format', {})
|
|
||||||
station = f.get('station') or station
|
|
||||||
|
|
||||||
STATIONS = {
|
|
||||||
'rtl': 'rtlnow',
|
|
||||||
'rtl2': 'rtl2now',
|
|
||||||
'vox': 'voxnow',
|
|
||||||
'nitro': 'rtlnitronow',
|
|
||||||
'ntv': 'n-tvnow',
|
|
||||||
'superrtl': 'superrtlnow'
|
|
||||||
}
|
|
||||||
|
|
||||||
formats = []
|
formats = []
|
||||||
for item in files['items']:
|
for item in files['items']:
|
||||||
item_path = remove_start(item['path'], '/')
|
if determine_ext(item['path']) != 'f4v':
|
||||||
tbr = int_or_none(item['bitrate'])
|
continue
|
||||||
m3u8_url = 'http://hls.fra.%s.de/hls-vod-enc/%s.m3u8' % (STATIONS[station], item_path)
|
app, play_path = remove_start(item['path'], '/').split('/', 1)
|
||||||
m3u8_url = m3u8_url.replace('now/', 'now/videos/')
|
|
||||||
formats.append({
|
formats.append({
|
||||||
'url': m3u8_url,
|
'url': 'rtmpe://fms.rtl.de',
|
||||||
'format_id': '%s-%sk' % (item['id'], tbr),
|
'app': app,
|
||||||
'ext': 'mp4',
|
'play_path': 'mp4:%s' % play_path,
|
||||||
'tbr': tbr,
|
'ext': 'flv',
|
||||||
|
'page_url': url,
|
||||||
|
'player_url': 'http://rtl-now.rtl.de/includes/nc_player.swf',
|
||||||
|
'tbr': int_or_none(item.get('bitrate')),
|
||||||
})
|
})
|
||||||
self._sort_formats(formats)
|
self._sort_formats(formats)
|
||||||
|
|
||||||
|
@ -178,6 +167,8 @@ class NowTVIE(InfoExtractor):
|
||||||
description = info.get('articleLong') or info.get('articleShort')
|
description = info.get('articleLong') or info.get('articleShort')
|
||||||
timestamp = parse_iso8601(info.get('broadcastStartDate'), ' ')
|
timestamp = parse_iso8601(info.get('broadcastStartDate'), ' ')
|
||||||
duration = parse_duration(info.get('duration'))
|
duration = parse_duration(info.get('duration'))
|
||||||
|
|
||||||
|
f = info.get('format', {})
|
||||||
thumbnail = f.get('defaultImage169Format') or f.get('defaultImage169Logo')
|
thumbnail = f.get('defaultImage169Format') or f.get('defaultImage169Logo')
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
|
Loading…
Reference in New Issue