mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-11-04 08:35:12 +00:00 
			
		
		
		
	[nowtv] Fix extraction (Closes #6357)
This commit is contained in:
		@@ -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 {
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user