mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-11-04 08:35:12 +00:00 
			
		
		
		
	[laola1] add support for another extraction scenario(closes #11460)
This commit is contained in:
		@@ -9,18 +9,41 @@ from ..utils import (
 | 
				
			|||||||
    xpath_element,
 | 
					    xpath_element,
 | 
				
			||||||
    xpath_text,
 | 
					    xpath_text,
 | 
				
			||||||
    urljoin,
 | 
					    urljoin,
 | 
				
			||||||
 | 
					    update_url_query,
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class Laola1TvEmbedIE(InfoExtractor):
 | 
					class Laola1TvEmbedIE(InfoExtractor):
 | 
				
			||||||
 | 
					    IE_NAME = 'laola1tv:embed'
 | 
				
			||||||
    _VALID_URL = r'https?://(?:www\.)?laola1\.tv/titanplayer\.php\?.*?\bvideoid=(?P<id>\d+)'
 | 
					    _VALID_URL = r'https?://(?:www\.)?laola1\.tv/titanplayer\.php\?.*?\bvideoid=(?P<id>\d+)'
 | 
				
			||||||
 | 
					    _TEST = {
 | 
				
			||||||
 | 
					        # flashvars.premium = "false";
 | 
				
			||||||
 | 
					        'url': 'https://www.laola1.tv/titanplayer.php?videoid=708065&type=V&lang=en&portal=int&customer=1024',
 | 
				
			||||||
 | 
					        'info_dict': {
 | 
				
			||||||
 | 
					            'id': '708065',
 | 
				
			||||||
 | 
					            'ext': 'mp4',
 | 
				
			||||||
 | 
					            'title': 'MA Long CHN - FAN Zhendong CHN',
 | 
				
			||||||
 | 
					            'uploader': 'ITTF - International Table Tennis Federation',
 | 
				
			||||||
 | 
					            'upload_date': '20161211',
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def _real_extract(self, url):
 | 
					    def _real_extract(self, url):
 | 
				
			||||||
        video_id = self._match_id(url)
 | 
					        video_id = self._match_id(url)
 | 
				
			||||||
        webpage = self._download_webpage(url, video_id)
 | 
					        webpage = self._download_webpage(url, video_id)
 | 
				
			||||||
        flash_vars = self._search_regex(
 | 
					        flash_vars = self._search_regex(
 | 
				
			||||||
            r'(?s)flashvars\s*=\s*({.+?});', webpage, 'flash vars')
 | 
					            r'(?s)flashvars\s*=\s*({.+?});', webpage, 'flash vars')
 | 
				
			||||||
        get_flashvar = lambda x: self._search_regex(r'%s\s*:\s*"([^"]+)"' % x, flash_vars, x)
 | 
					
 | 
				
			||||||
 | 
					        def get_flashvar(x, *args, **kwargs):
 | 
				
			||||||
 | 
					            flash_var = self._search_regex(
 | 
				
			||||||
 | 
					                r'%s\s*:\s*"([^"]+)"' % x,
 | 
				
			||||||
 | 
					                flash_vars, x, default=None)
 | 
				
			||||||
 | 
					            if not flash_var:
 | 
				
			||||||
 | 
					                flash_var = self._search_regex([
 | 
				
			||||||
 | 
					                    r'flashvars\.%s\s*=\s*"([^"]+)"' % x,
 | 
				
			||||||
 | 
					                    r'%s\s*=\s*"([^"]+)"' % x],
 | 
				
			||||||
 | 
					                    webpage, x, *args, **kwargs)
 | 
				
			||||||
 | 
					            return flash_var
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        hd_doc = self._download_xml(
 | 
					        hd_doc = self._download_xml(
 | 
				
			||||||
            'http://www.laola1.tv/server/hd_video.php', video_id, query={
 | 
					            'http://www.laola1.tv/server/hd_video.php', video_id, query={
 | 
				
			||||||
@@ -34,16 +57,26 @@ class Laola1TvEmbedIE(InfoExtractor):
 | 
				
			|||||||
        _v = lambda x, **k: xpath_text(hd_doc, './/video/' + x, **k)
 | 
					        _v = lambda x, **k: xpath_text(hd_doc, './/video/' + x, **k)
 | 
				
			||||||
        title = _v('title', fatal=True)
 | 
					        title = _v('title', fatal=True)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        data_abo = urlencode_postdata(
 | 
					        token_url = None
 | 
				
			||||||
            dict((i, v) for i, v in enumerate(_v('req_liga_abos').split(','))))
 | 
					        premium = get_flashvar('premium', default=None)
 | 
				
			||||||
        token_url = self._download_json(
 | 
					        if premium:
 | 
				
			||||||
            'https://club.laola1.tv/sp/laola1/api/v3/user/session/premium/player/stream-access',
 | 
					            token_url = update_url_query(
 | 
				
			||||||
            video_id, query={
 | 
					                _v('url', fatal=True), {
 | 
				
			||||||
                'videoId': _v('id'),
 | 
					                    'timestamp': get_flashvar('timestamp'),
 | 
				
			||||||
                'target': self._search_regex(r'vs_target = (\d+);', webpage, 'vs target'),
 | 
					                    'auth': get_flashvar('auth'),
 | 
				
			||||||
                'label': _v('label'),
 | 
					                })
 | 
				
			||||||
                'area': _v('area'),
 | 
					        else:
 | 
				
			||||||
            }, data=data_abo)['data']['stream-access'][0]
 | 
					            data_abo = urlencode_postdata(
 | 
				
			||||||
 | 
					                dict((i, v) for i, v in enumerate(_v('req_liga_abos').split(','))))
 | 
				
			||||||
 | 
					            token_url = self._download_json(
 | 
				
			||||||
 | 
					                'https://club.laola1.tv/sp/laola1/api/v3/user/session/premium/player/stream-access',
 | 
				
			||||||
 | 
					                video_id, query={
 | 
				
			||||||
 | 
					                    'videoId': _v('id'),
 | 
				
			||||||
 | 
					                    'target': self._search_regex(r'vs_target = (\d+);', webpage, 'vs target'),
 | 
				
			||||||
 | 
					                    'label': _v('label'),
 | 
				
			||||||
 | 
					                    'area': _v('area'),
 | 
				
			||||||
 | 
					                }, data=data_abo)['data']['stream-access'][0]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        token_doc = self._download_xml(
 | 
					        token_doc = self._download_xml(
 | 
				
			||||||
            token_url, video_id, 'Downloading token',
 | 
					            token_url, video_id, 'Downloading token',
 | 
				
			||||||
            headers=self.geo_verification_headers())
 | 
					            headers=self.geo_verification_headers())
 | 
				
			||||||
@@ -75,6 +108,7 @@ class Laola1TvEmbedIE(InfoExtractor):
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class Laola1TvIE(InfoExtractor):
 | 
					class Laola1TvIE(InfoExtractor):
 | 
				
			||||||
 | 
					    IE_NAME = 'laola1tv'
 | 
				
			||||||
    _VALID_URL = r'https?://(?:www\.)?laola1\.tv/[a-z]+-[a-z]+/[^/]+/(?P<id>[^/?#&]+)'
 | 
					    _VALID_URL = r'https?://(?:www\.)?laola1\.tv/[a-z]+-[a-z]+/[^/]+/(?P<id>[^/?#&]+)'
 | 
				
			||||||
    _TESTS = [{
 | 
					    _TESTS = [{
 | 
				
			||||||
        'url': 'http://www.laola1.tv/de-de/video/straubing-tigers-koelner-haie/227883.html',
 | 
					        'url': 'http://www.laola1.tv/de-de/video/straubing-tigers-koelner-haie/227883.html',
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user