mirror of
				https://gitlab.com/ytdl-org/youtube-dl.git
				synced 2025-11-04 03:27:06 -05:00 
			
		
		
		
	[twitch:vod] Prefer source stream (Fixes #5143)
This commit is contained in:
		@@ -85,6 +85,14 @@ class TwitchBaseIE(InfoExtractor):
 | 
			
		||||
            raise ExtractorError(
 | 
			
		||||
                'Unable to login: %s' % m.group('msg').strip(), expected=True)
 | 
			
		||||
 | 
			
		||||
    def _prefer_source(self, formats):
 | 
			
		||||
        try:
 | 
			
		||||
            source = next(f for f in formats if f['format_id'] == 'Source')
 | 
			
		||||
            source['preference'] = 10
 | 
			
		||||
        except StopIteration:
 | 
			
		||||
            pass  # No Source stream present
 | 
			
		||||
        self._sort_formats(formats)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class TwitchItemBaseIE(TwitchBaseIE):
 | 
			
		||||
    def _download_info(self, item, item_id):
 | 
			
		||||
@@ -209,6 +217,7 @@ class TwitchVodIE(TwitchItemBaseIE):
 | 
			
		||||
            '%s/vod/%s?nauth=%s&nauthsig=%s'
 | 
			
		||||
            % (self._USHER_BASE, item_id, access_token['token'], access_token['sig']),
 | 
			
		||||
            item_id, 'mp4')
 | 
			
		||||
        self._prefer_source(formats)
 | 
			
		||||
        info['formats'] = formats
 | 
			
		||||
        return info
 | 
			
		||||
 | 
			
		||||
@@ -357,13 +366,7 @@ class TwitchStreamIE(TwitchBaseIE):
 | 
			
		||||
            '%s/api/channel/hls/%s.m3u8?%s'
 | 
			
		||||
            % (self._USHER_BASE, channel_id, compat_urllib_parse.urlencode(query).encode('utf-8')),
 | 
			
		||||
            channel_id, 'mp4')
 | 
			
		||||
 | 
			
		||||
        # prefer the 'source' stream, the others are limited to 30 fps
 | 
			
		||||
        def _sort_source(f):
 | 
			
		||||
            if f.get('m3u8_media') is not None and f['m3u8_media'].get('NAME') == 'Source':
 | 
			
		||||
                return 1
 | 
			
		||||
            return 0
 | 
			
		||||
        formats = sorted(formats, key=_sort_source)
 | 
			
		||||
        self._prefer_source(formats)
 | 
			
		||||
 | 
			
		||||
        view_count = stream.get('viewers')
 | 
			
		||||
        timestamp = parse_iso8601(stream.get('created_at'))
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user