[youtube] Also use the 'adaptative_fmts' field from the /get_video_info page (fixes #1649)
The 'adaptative_fmts' field from the video page is not added to the 'url_encoded_fmt_stream_map'
This commit is contained in:
		@@ -1405,32 +1405,29 @@ class YoutubeIE(YoutubeBaseInfoExtractor, SubtitlesInfoExtractor):
 | 
			
		||||
            # this signatures are encrypted
 | 
			
		||||
            if 'url_encoded_fmt_stream_map' not in args:
 | 
			
		||||
                raise ValueError(u'No stream_map present')  # caught below
 | 
			
		||||
            m_s = re.search(r'[&,]s=', args['url_encoded_fmt_stream_map'])
 | 
			
		||||
            re_signature = re.compile(r'[&,]s=')
 | 
			
		||||
            m_s = re_signature.search(args['url_encoded_fmt_stream_map'])
 | 
			
		||||
            if m_s is not None:
 | 
			
		||||
                self.to_screen(u'%s: Encrypted signatures detected.' % video_id)
 | 
			
		||||
                video_info['url_encoded_fmt_stream_map'] = [args['url_encoded_fmt_stream_map']]
 | 
			
		||||
            m_s = re.search(r'[&,]s=', args.get('adaptive_fmts', u''))
 | 
			
		||||
            m_s = re_signature.search(args.get('adaptive_fmts', u''))
 | 
			
		||||
            if m_s is not None:
 | 
			
		||||
                if 'url_encoded_fmt_stream_map' in video_info:
 | 
			
		||||
                    video_info['url_encoded_fmt_stream_map'][0] += ',' + args['adaptive_fmts']
 | 
			
		||||
                if 'adaptive_fmts' in video_info:
 | 
			
		||||
                    video_info['adaptive_fmts'][0] += ',' + args['adaptive_fmts']
 | 
			
		||||
                else:
 | 
			
		||||
                    video_info['url_encoded_fmt_stream_map'] = [args['adaptive_fmts']]
 | 
			
		||||
            elif 'adaptive_fmts' in video_info:
 | 
			
		||||
                if 'url_encoded_fmt_stream_map' in video_info:
 | 
			
		||||
                    video_info['url_encoded_fmt_stream_map'][0] += ',' + video_info['adaptive_fmts'][0]
 | 
			
		||||
                else:
 | 
			
		||||
                    video_info['url_encoded_fmt_stream_map'] = video_info['adaptive_fmts']
 | 
			
		||||
                    video_info['adaptive_fmts'] = [args['adaptive_fmts']]
 | 
			
		||||
        except ValueError:
 | 
			
		||||
            pass
 | 
			
		||||
 | 
			
		||||
        if 'conn' in video_info and video_info['conn'][0].startswith('rtmp'):
 | 
			
		||||
            self.report_rtmp_download()
 | 
			
		||||
            video_url_list = [(None, video_info['conn'][0])]
 | 
			
		||||
        elif 'url_encoded_fmt_stream_map' in video_info and len(video_info['url_encoded_fmt_stream_map']) >= 1:
 | 
			
		||||
            if 'rtmpe%3Dyes' in video_info['url_encoded_fmt_stream_map'][0]:
 | 
			
		||||
        elif len(video_info.get('url_encoded_fmt_stream_map', [])) >= 1 or len(video_info.get('adaptive_fmts', [])) >= 1:
 | 
			
		||||
            encoded_url_map = video_info.get('url_encoded_fmt_stream_map', [''])[0] + ',' + video_info.get('adaptive_fmts',[''])[0]
 | 
			
		||||
            if 'rtmpe%3Dyes' in encoded_url_map:
 | 
			
		||||
                raise ExtractorError('rtmpe downloads are not supported, see https://github.com/rg3/youtube-dl/issues/343 for more information.', expected=True)
 | 
			
		||||
            url_map = {}
 | 
			
		||||
            for url_data_str in video_info['url_encoded_fmt_stream_map'][0].split(','):
 | 
			
		||||
            for url_data_str in encoded_url_map.split(','):
 | 
			
		||||
                url_data = compat_parse_qs(url_data_str)
 | 
			
		||||
                if 'itag' in url_data and 'url' in url_data:
 | 
			
		||||
                    url = url_data['url'][0]
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user