mirror of
				https://github.com/ytdl-org/youtube-dl
				synced 2025-10-31 17:53:11 +00:00 
			
		
		
		
	[youtube] add support phone/tablet JS player(closes #26424)
This commit is contained in:
		
							parent
							
								
									5fc53690cb
								
							
						
					
					
						commit
						99c68db0a8
					
				| @ -19,55 +19,46 @@ from youtube_dl.compat import compat_str, compat_urlretrieve | |||||||
| _TESTS = [ | _TESTS = [ | ||||||
|     ( |     ( | ||||||
|         'https://s.ytimg.com/yts/jsbin/html5player-vflHOr_nV.js', |         'https://s.ytimg.com/yts/jsbin/html5player-vflHOr_nV.js', | ||||||
|         'js', |  | ||||||
|         86, |         86, | ||||||
|         '>=<;:/.-[+*)(\'&%$#"!ZYX0VUTSRQPONMLKJIHGFEDCBA\\yxwvutsrqponmlkjihgfedcba987654321', |         '>=<;:/.-[+*)(\'&%$#"!ZYX0VUTSRQPONMLKJIHGFEDCBA\\yxwvutsrqponmlkjihgfedcba987654321', | ||||||
|     ), |     ), | ||||||
|     ( |     ( | ||||||
|         'https://s.ytimg.com/yts/jsbin/html5player-vfldJ8xgI.js', |         'https://s.ytimg.com/yts/jsbin/html5player-vfldJ8xgI.js', | ||||||
|         'js', |  | ||||||
|         85, |         85, | ||||||
|         '3456789a0cdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRS[UVWXYZ!"#$%&\'()*+,-./:;<=>?@', |         '3456789a0cdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRS[UVWXYZ!"#$%&\'()*+,-./:;<=>?@', | ||||||
|     ), |     ), | ||||||
|     ( |     ( | ||||||
|         'https://s.ytimg.com/yts/jsbin/html5player-vfle-mVwz.js', |         'https://s.ytimg.com/yts/jsbin/html5player-vfle-mVwz.js', | ||||||
|         'js', |  | ||||||
|         90, |         90, | ||||||
|         ']\\[@?>=<;:/.-,+*)(\'&%$#"hZYXWVUTSRQPONMLKJIHGFEDCBAzyxwvutsrqponmlkjiagfedcb39876', |         ']\\[@?>=<;:/.-,+*)(\'&%$#"hZYXWVUTSRQPONMLKJIHGFEDCBAzyxwvutsrqponmlkjiagfedcb39876', | ||||||
|     ), |     ), | ||||||
|     ( |     ( | ||||||
|         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vfl0Cbn9e.js', |         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vfl0Cbn9e.js', | ||||||
|         'js', |  | ||||||
|         84, |         84, | ||||||
|         'O1I3456789abcde0ghijklmnopqrstuvwxyzABCDEFGHfJKLMN2PQRSTUVW@YZ!"#$%&\'()*+,-./:;<=', |         'O1I3456789abcde0ghijklmnopqrstuvwxyzABCDEFGHfJKLMN2PQRSTUVW@YZ!"#$%&\'()*+,-./:;<=', | ||||||
|     ), |     ), | ||||||
|     ( |     ( | ||||||
|         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vflXGBaUN.js', |         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vflXGBaUN.js', | ||||||
|         'js', |  | ||||||
|         '2ACFC7A61CA478CD21425E5A57EBD73DDC78E22A.2094302436B2D377D14A3BBA23022D023B8BC25AA', |         '2ACFC7A61CA478CD21425E5A57EBD73DDC78E22A.2094302436B2D377D14A3BBA23022D023B8BC25AA', | ||||||
|         'A52CB8B320D22032ABB3A41D773D2B6342034902.A22E87CDD37DBE75A5E52412DC874AC16A7CFCA2', |         'A52CB8B320D22032ABB3A41D773D2B6342034902.A22E87CDD37DBE75A5E52412DC874AC16A7CFCA2', | ||||||
|     ), |     ), | ||||||
|     ( |     ( | ||||||
|         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vflBb0OQx.js', |         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vflBb0OQx.js', | ||||||
|         'js', |  | ||||||
|         84, |         84, | ||||||
|         '123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQ0STUVWXYZ!"#$%&\'()*+,@./:;<=>' |         '123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQ0STUVWXYZ!"#$%&\'()*+,@./:;<=>' | ||||||
|     ), |     ), | ||||||
|     ( |     ( | ||||||
|         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vfl9FYC6l.js', |         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vfl9FYC6l.js', | ||||||
|         'js', |  | ||||||
|         83, |         83, | ||||||
|         '123456789abcdefghijklmnopqr0tuvwxyzABCDETGHIJKLMNOPQRS>UVWXYZ!"#$%&\'()*+,-./:;<=F' |         '123456789abcdefghijklmnopqr0tuvwxyzABCDETGHIJKLMNOPQRS>UVWXYZ!"#$%&\'()*+,-./:;<=F' | ||||||
|     ), |     ), | ||||||
|     ( |     ( | ||||||
|         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vflCGk6yw/html5player.js', |         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vflCGk6yw/html5player.js', | ||||||
|         'js', |  | ||||||
|         '4646B5181C6C3020DF1D9C7FCFEA.AD80ABF70C39BD369CCCAE780AFBB98FA6B6CB42766249D9488C288', |         '4646B5181C6C3020DF1D9C7FCFEA.AD80ABF70C39BD369CCCAE780AFBB98FA6B6CB42766249D9488C288', | ||||||
|         '82C8849D94266724DC6B6AF89BBFA087EACCD963.B93C07FBA084ACAEFCF7C9D1FD0203C6C1815B6B' |         '82C8849D94266724DC6B6AF89BBFA087EACCD963.B93C07FBA084ACAEFCF7C9D1FD0203C6C1815B6B' | ||||||
|     ), |     ), | ||||||
|     ( |     ( | ||||||
|         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vflKjOTVq/html5player.js', |         'https://s.ytimg.com/yts/jsbin/html5player-en_US-vflKjOTVq/html5player.js', | ||||||
|         'js', |  | ||||||
|         '312AA52209E3623129A412D56A40F11CB0AF14AE.3EE09501CB14E3BCDC3B2AE808BF3F1D14E7FBF12', |         '312AA52209E3623129A412D56A40F11CB0AF14AE.3EE09501CB14E3BCDC3B2AE808BF3F1D14E7FBF12', | ||||||
|         '112AA5220913623229A412D56A40F11CB0AF14AE.3EE0950FCB14EEBCDC3B2AE808BF331D14E7FBF3', |         '112AA5220913623229A412D56A40F11CB0AF14AE.3EE0950FCB14EEBCDC3B2AE808BF331D14E7FBF3', | ||||||
|     ) |     ) | ||||||
| @ -78,6 +69,10 @@ class TestPlayerInfo(unittest.TestCase): | |||||||
|     def test_youtube_extract_player_info(self): |     def test_youtube_extract_player_info(self): | ||||||
|         PLAYER_URLS = ( |         PLAYER_URLS = ( | ||||||
|             ('https://www.youtube.com/s/player/64dddad9/player_ias.vflset/en_US/base.js', '64dddad9'), |             ('https://www.youtube.com/s/player/64dddad9/player_ias.vflset/en_US/base.js', '64dddad9'), | ||||||
|  |             ('https://www.youtube.com/s/player/64dddad9/player_ias.vflset/fr_FR/base.js', '64dddad9'), | ||||||
|  |             ('https://www.youtube.com/s/player/64dddad9/player-plasma-ias-phone-en_US.vflset/base.js', '64dddad9'), | ||||||
|  |             ('https://www.youtube.com/s/player/64dddad9/player-plasma-ias-phone-de_DE.vflset/base.js', '64dddad9'), | ||||||
|  |             ('https://www.youtube.com/s/player/64dddad9/player-plasma-ias-tablet-en_US.vflset/base.js', '64dddad9'), | ||||||
|             # obsolete |             # obsolete | ||||||
|             ('https://www.youtube.com/yts/jsbin/player_ias-vfle4-e03/en_US/base.js', 'vfle4-e03'), |             ('https://www.youtube.com/yts/jsbin/player_ias-vfle4-e03/en_US/base.js', 'vfle4-e03'), | ||||||
|             ('https://www.youtube.com/yts/jsbin/player_ias-vfl49f_g4/en_US/base.js', 'vfl49f_g4'), |             ('https://www.youtube.com/yts/jsbin/player_ias-vfl49f_g4/en_US/base.js', 'vfl49f_g4'), | ||||||
| @ -100,13 +95,13 @@ class TestSignature(unittest.TestCase): | |||||||
|             os.mkdir(self.TESTDATA_DIR) |             os.mkdir(self.TESTDATA_DIR) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def make_tfunc(url, stype, sig_input, expected_sig): | def make_tfunc(url, sig_input, expected_sig): | ||||||
|     m = re.match(r'.*-([a-zA-Z0-9_-]+)(?:/watch_as3|/html5player)?\.[a-z]+$', url) |     m = re.match(r'.*-([a-zA-Z0-9_-]+)(?:/watch_as3|/html5player)?\.[a-z]+$', url) | ||||||
|     assert m, '%r should follow URL format' % url |     assert m, '%r should follow URL format' % url | ||||||
|     test_id = m.group(1) |     test_id = m.group(1) | ||||||
| 
 | 
 | ||||||
|     def test_func(self): |     def test_func(self): | ||||||
|         basename = 'player-%s.%s' % (test_id, stype) |         basename = 'player-%s.js' % test_id | ||||||
|         fn = os.path.join(self.TESTDATA_DIR, basename) |         fn = os.path.join(self.TESTDATA_DIR, basename) | ||||||
| 
 | 
 | ||||||
|         if not os.path.exists(fn): |         if not os.path.exists(fn): | ||||||
| @ -114,22 +109,16 @@ def make_tfunc(url, stype, sig_input, expected_sig): | |||||||
| 
 | 
 | ||||||
|         ydl = FakeYDL() |         ydl = FakeYDL() | ||||||
|         ie = YoutubeIE(ydl) |         ie = YoutubeIE(ydl) | ||||||
|         if stype == 'js': |         with io.open(fn, encoding='utf-8') as testf: | ||||||
|             with io.open(fn, encoding='utf-8') as testf: |             jscode = testf.read() | ||||||
|                 jscode = testf.read() |         func = ie._parse_sig_js(jscode) | ||||||
|             func = ie._parse_sig_js(jscode) |  | ||||||
|         else: |  | ||||||
|             assert stype == 'swf' |  | ||||||
|             with open(fn, 'rb') as testf: |  | ||||||
|                 swfcode = testf.read() |  | ||||||
|             func = ie._parse_sig_swf(swfcode) |  | ||||||
|         src_sig = ( |         src_sig = ( | ||||||
|             compat_str(string.printable[:sig_input]) |             compat_str(string.printable[:sig_input]) | ||||||
|             if isinstance(sig_input, int) else sig_input) |             if isinstance(sig_input, int) else sig_input) | ||||||
|         got_sig = func(src_sig) |         got_sig = func(src_sig) | ||||||
|         self.assertEqual(got_sig, expected_sig) |         self.assertEqual(got_sig, expected_sig) | ||||||
| 
 | 
 | ||||||
|     test_func.__name__ = str('test_signature_' + stype + '_' + test_id) |     test_func.__name__ = str('test_signature_js_' + test_id) | ||||||
|     setattr(TestSignature, test_func.__name__, test_func) |     setattr(TestSignature, test_func.__name__, test_func) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -398,7 +398,8 @@ class YoutubeIE(YoutubeBaseInfoExtractor): | |||||||
|                      (?(1).+)?                                                # if we found the ID, everything can follow |                      (?(1).+)?                                                # if we found the ID, everything can follow | ||||||
|                      $""" % {'playlist_id': YoutubeBaseInfoExtractor._PLAYLIST_ID_RE} |                      $""" % {'playlist_id': YoutubeBaseInfoExtractor._PLAYLIST_ID_RE} | ||||||
|     _PLAYER_INFO_RE = ( |     _PLAYER_INFO_RE = ( | ||||||
|         r'/(?P<id>[a-zA-Z0-9_-]{8,})/player_ias\.vflset(?:/[a-zA-Z]{2,3}_[a-zA-Z]{2,3})?/base\.js$', |         r'/s/player/(?P<id>[a-zA-Z0-9_-]{8,})/player', | ||||||
|  |         r'/(?P<id>[a-zA-Z0-9_-]{8,})/player(?:_ias\.vflset(?:/[a-zA-Z]{2,3}_[a-zA-Z]{2,3})?|-plasma-ias-(?:phone|tablet)-[a-z]{2}_[A-Z]{2}\.vflset)/base\.js$', | ||||||
|         r'\b(?P<id>vfl[a-zA-Z0-9_-]+)\b.*?\.js$', |         r'\b(?P<id>vfl[a-zA-Z0-9_-]+)\b.*?\.js$', | ||||||
|     ) |     ) | ||||||
|     _SUBTITLE_FORMATS = ('srv1', 'srv2', 'srv3', 'ttml', 'vtt') |     _SUBTITLE_FORMATS = ('srv1', 'srv2', 'srv3', 'ttml', 'vtt') | ||||||
| @ -1237,6 +1238,9 @@ class YoutubeIE(YoutubeBaseInfoExtractor): | |||||||
|         funcname = self._search_regex( |         funcname = self._search_regex( | ||||||
|             (r'\b[cs]\s*&&\s*[adf]\.set\([^,]+\s*,\s*encodeURIComponent\s*\(\s*(?P<sig>[a-zA-Z0-9$]+)\(', |             (r'\b[cs]\s*&&\s*[adf]\.set\([^,]+\s*,\s*encodeURIComponent\s*\(\s*(?P<sig>[a-zA-Z0-9$]+)\(', | ||||||
|              r'\b[a-zA-Z0-9]+\s*&&\s*[a-zA-Z0-9]+\.set\([^,]+\s*,\s*encodeURIComponent\s*\(\s*(?P<sig>[a-zA-Z0-9$]+)\(', |              r'\b[a-zA-Z0-9]+\s*&&\s*[a-zA-Z0-9]+\.set\([^,]+\s*,\s*encodeURIComponent\s*\(\s*(?P<sig>[a-zA-Z0-9$]+)\(', | ||||||
|  |              r'\bm=(?P<sig>[a-zA-Z0-9$]{2})\(decodeURIComponent\(h\.s\)\)', | ||||||
|  |              r'\bc&&\(c=(?P<sig>[a-zA-Z0-9$]{2})\(decodeURIComponent\(c\)\)', | ||||||
|  |              r'(?:\b|[^a-zA-Z0-9$])(?P<sig>[a-zA-Z0-9$]{2})\s*=\s*function\(\s*a\s*\)\s*{\s*a\s*=\s*a\.split\(\s*""\s*\);[a-zA-Z0-9$]{2}\.[a-zA-Z0-9$]{2}\(a,\d+\)', | ||||||
|              r'(?:\b|[^a-zA-Z0-9$])(?P<sig>[a-zA-Z0-9$]{2})\s*=\s*function\(\s*a\s*\)\s*{\s*a\s*=\s*a\.split\(\s*""\s*\)', |              r'(?:\b|[^a-zA-Z0-9$])(?P<sig>[a-zA-Z0-9$]{2})\s*=\s*function\(\s*a\s*\)\s*{\s*a\s*=\s*a\.split\(\s*""\s*\)', | ||||||
|              r'(?P<sig>[a-zA-Z0-9$]+)\s*=\s*function\(\s*a\s*\)\s*{\s*a\s*=\s*a\.split\(\s*""\s*\)', |              r'(?P<sig>[a-zA-Z0-9$]+)\s*=\s*function\(\s*a\s*\)\s*{\s*a\s*=\s*a\.split\(\s*""\s*\)', | ||||||
|              # Obsolete patterns |              # Obsolete patterns | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Remita Amine
						Remita Amine