mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-26 20:21:05 +00:00 
			
		
		
		
	 bfd973ece3
			
		
	
	
		bfd973ece3
		
	
	
	
	
		
			
			`Brightcove` is difficult to migrate because it's subclasses may depend on the signature of the current functions. So it is left as-is for now Note: Tests have not been migrated
		
			
				
	
	
		
			25 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			25 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import re
 | |
| import urllib.parse
 | |
| from .common import InfoExtractor
 | |
| from ..compat import compat_urllib_parse_unquote
 | |
| 
 | |
| 
 | |
| class EmbedlyIE(InfoExtractor):
 | |
|     _VALID_URL = r'https?://(?:www|cdn\.)?embedly\.com/widgets/media\.html\?(?:[^#]*?&)?url=(?P<id>[^#&]+)'
 | |
|     _TESTS = [{
 | |
|         'url': 'https://cdn.embedly.com/widgets/media.html?src=http%3A%2F%2Fwww.youtube.com%2Fembed%2Fvideoseries%3Flist%3DUUGLim4T2loE5rwCMdpCIPVg&url=https%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3DSU4fj_aEMVw%26list%3DUUGLim4T2loE5rwCMdpCIPVg&image=http%3A%2F%2Fi.ytimg.com%2Fvi%2FSU4fj_aEMVw%2Fhqdefault.jpg&key=8ee8a2e6a8cc47aab1a5ee67f9a178e0&type=text%2Fhtml&schema=youtube&autoplay=1',
 | |
|         'only_matching': True,
 | |
|     }]
 | |
| 
 | |
|     @classmethod
 | |
|     def _extract_embed_urls(cls, url, webpage):
 | |
|         # Bypass suitable check
 | |
|         for mobj in re.finditer(r'class=["\']embedly-card["\'][^>]href=["\'](?P<url>[^"\']+)', webpage):
 | |
|             yield mobj.group('url')
 | |
| 
 | |
|         for mobj in re.finditer(r'class=["\']embedly-embed["\'][^>]src=["\'][^"\']*url=(?P<url>[^&]+)', webpage):
 | |
|             yield urllib.parse.unquote(mobj.group('url'))
 | |
| 
 | |
|     def _real_extract(self, url):
 | |
|         return self.url_result(compat_urllib_parse_unquote(self._match_id(url)))
 |