mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-11-04 00:25:15 +00:00 
			
		
		
		
	@@ -20,18 +20,18 @@ class LifeNewsIE(InfoExtractor):
 | 
			
		||||
    _VALID_URL = r'http://lifenews\.ru/(?:mobile/)?(?P<section>news|video)/(?P<id>\d+)'
 | 
			
		||||
 | 
			
		||||
    _TESTS = [{
 | 
			
		||||
        'url': 'http://lifenews.ru/news/126342',
 | 
			
		||||
        'md5': 'e1b50a5c5fb98a6a544250f2e0db570a',
 | 
			
		||||
        # single video embedded via video/source
 | 
			
		||||
        'url': 'http://lifenews.ru/news/98736',
 | 
			
		||||
        'md5': '77c95eaefaca216e32a76a343ad89d23',
 | 
			
		||||
        'info_dict': {
 | 
			
		||||
            'id': '126342',
 | 
			
		||||
            'id': '98736',
 | 
			
		||||
            'ext': 'mp4',
 | 
			
		||||
            'title': 'МВД разыскивает мужчин, оставивших в IKEA сумку с автоматом',
 | 
			
		||||
            'description': 'Камеры наблюдения гипермаркета зафиксировали троих мужчин, спрятавших оружейный арсенал в камере хранения.',
 | 
			
		||||
            'thumbnail': 're:http://.*\.jpg',
 | 
			
		||||
            'upload_date': '20140130',
 | 
			
		||||
            'title': 'Мужчина нашел дома архив оборонного завода',
 | 
			
		||||
            'description': 'md5:3b06b1b39b5e2bea548e403d99b8bf26',
 | 
			
		||||
            'upload_date': '20120805',
 | 
			
		||||
        }
 | 
			
		||||
    }, {
 | 
			
		||||
        # video in <iframe>
 | 
			
		||||
        # single video embedded via iframe
 | 
			
		||||
        'url': 'http://lifenews.ru/news/152125',
 | 
			
		||||
        'md5': '77d19a6f0886cd76bdbf44b4d971a273',
 | 
			
		||||
        'info_dict': {
 | 
			
		||||
@@ -42,15 +42,33 @@ class LifeNewsIE(InfoExtractor):
 | 
			
		||||
            'upload_date': '20150402',
 | 
			
		||||
        }
 | 
			
		||||
    }, {
 | 
			
		||||
        # two videos embedded via iframe
 | 
			
		||||
        'url': 'http://lifenews.ru/news/153461',
 | 
			
		||||
        'md5': '9b6ef8bc0ffa25aebc8bdb40d89ab795',
 | 
			
		||||
        'info_dict': {
 | 
			
		||||
            'id': '153461',
 | 
			
		||||
            'ext': 'mp4',
 | 
			
		||||
            'title': 'В Москве спасли потерявшегося медвежонка, который спрятался на дереве',
 | 
			
		||||
            'description': 'Маленький хищник не смог найти дорогу домой и обрел временное убежище на тополе недалеко от жилого массива, пока его не нашла соседская собака.',
 | 
			
		||||
            'upload_date': '20150505',
 | 
			
		||||
        }
 | 
			
		||||
        },
 | 
			
		||||
        'playlist': [{
 | 
			
		||||
            'md5': '9b6ef8bc0ffa25aebc8bdb40d89ab795',
 | 
			
		||||
            'info_dict': {
 | 
			
		||||
                'id': '153461-video1',
 | 
			
		||||
                'ext': 'mp4',
 | 
			
		||||
                'title': 'В Москве спасли потерявшегося медвежонка, который спрятался на дереве (Видео 1)',
 | 
			
		||||
                'description': 'Маленький хищник не смог найти дорогу домой и обрел временное убежище на тополе недалеко от жилого массива, пока его не нашла соседская собака.',
 | 
			
		||||
                'upload_date': '20150505',
 | 
			
		||||
            },
 | 
			
		||||
        }, {
 | 
			
		||||
            'md5': 'ebb3bf3b1ce40e878d0d628e93eb0322',
 | 
			
		||||
            'info_dict': {
 | 
			
		||||
                'id': '153461-video2',
 | 
			
		||||
                'ext': 'mp4',
 | 
			
		||||
                'title': 'В Москве спасли потерявшегося медвежонка, который спрятался на дереве (Видео 2)',
 | 
			
		||||
                'description': 'Маленький хищник не смог найти дорогу домой и обрел временное убежище на тополе недалеко от жилого массива, пока его не нашла соседская собака.',
 | 
			
		||||
                'upload_date': '20150505',
 | 
			
		||||
            },
 | 
			
		||||
        }],
 | 
			
		||||
    }, {
 | 
			
		||||
        'url': 'http://lifenews.ru/video/13035',
 | 
			
		||||
        'only_matching': True,
 | 
			
		||||
@@ -65,10 +83,14 @@ class LifeNewsIE(InfoExtractor):
 | 
			
		||||
            'http://lifenews.ru/%s/%s' % (section, video_id),
 | 
			
		||||
            video_id, 'Downloading page')
 | 
			
		||||
 | 
			
		||||
        videos = re.findall(r'<video.*?poster="(?P<poster>[^"]+)".*?src="(?P<video>[^"]+)".*?></video>', webpage)
 | 
			
		||||
        iframe_link = self._html_search_regex(
 | 
			
		||||
            '<iframe[^>]+src=["\']([^"\']+)["\']', webpage, 'iframe link', default=None)
 | 
			
		||||
        if not videos and not iframe_link:
 | 
			
		||||
        video_urls = re.findall(
 | 
			
		||||
            r'<video[^>]+><source[^>]+src=["\'](.+?)["\']', webpage)
 | 
			
		||||
 | 
			
		||||
        iframe_links = re.findall(
 | 
			
		||||
            r'<iframe[^>]+src=["\']((?:https?:)?//embed\.life\.ru/embed/.+?)["\']',
 | 
			
		||||
            webpage)
 | 
			
		||||
 | 
			
		||||
        if not video_urls and not iframe_links:
 | 
			
		||||
            raise ExtractorError('No media links available for %s' % video_id)
 | 
			
		||||
 | 
			
		||||
        title = remove_end(
 | 
			
		||||
@@ -95,31 +117,44 @@ class LifeNewsIE(InfoExtractor):
 | 
			
		||||
            'upload_date': upload_date,
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        def make_entry(video_id, media, video_number=None):
 | 
			
		||||
        def make_entry(video_id, video_url, index=None):
 | 
			
		||||
            cur_info = dict(common_info)
 | 
			
		||||
            cur_info.update({
 | 
			
		||||
                'id': video_id,
 | 
			
		||||
                'url': media[1],
 | 
			
		||||
                'thumbnail': media[0],
 | 
			
		||||
                'title': title if video_number is None else '%s-video%s' % (title, video_number),
 | 
			
		||||
                'id': video_id if not index else '%s-video%s' % (video_id, index),
 | 
			
		||||
                'url': video_url,
 | 
			
		||||
                'title': title if not index else '%s (Видео %s)' % (title, index),
 | 
			
		||||
            })
 | 
			
		||||
            return cur_info
 | 
			
		||||
 | 
			
		||||
        if iframe_link:
 | 
			
		||||
            iframe_link = self._proto_relative_url(iframe_link, 'http:')
 | 
			
		||||
            cur_info = dict(common_info)
 | 
			
		||||
            cur_info.update({
 | 
			
		||||
                '_type': 'url_transparent',
 | 
			
		||||
                'id': video_id,
 | 
			
		||||
                'title': title,
 | 
			
		||||
                'url': iframe_link,
 | 
			
		||||
            })
 | 
			
		||||
        def make_video_entry(video_id, video_url, index=None):
 | 
			
		||||
            video_url = compat_urlparse.urljoin(url, video_url)
 | 
			
		||||
            return make_entry(video_id, video_url, index)
 | 
			
		||||
 | 
			
		||||
        def make_iframe_entry(video_id, video_url, index=None):
 | 
			
		||||
            video_url = self._proto_relative_url(video_url, 'http:')
 | 
			
		||||
            cur_info = make_entry(video_id, video_url, index)
 | 
			
		||||
            cur_info['_type'] = 'url_transparent'
 | 
			
		||||
            return cur_info
 | 
			
		||||
 | 
			
		||||
        if len(videos) == 1:
 | 
			
		||||
            return make_entry(video_id, videos[0])
 | 
			
		||||
        else:
 | 
			
		||||
            return [make_entry(video_id, media, video_number + 1) for video_number, media in enumerate(videos)]
 | 
			
		||||
        if len(video_urls) == 1 and not iframe_links:
 | 
			
		||||
            return make_video_entry(video_id, video_urls[0])
 | 
			
		||||
 | 
			
		||||
        if len(iframe_links) == 1 and not video_urls:
 | 
			
		||||
            return make_iframe_entry(video_id, iframe_links[0])
 | 
			
		||||
 | 
			
		||||
        entries = []
 | 
			
		||||
 | 
			
		||||
        if video_urls:
 | 
			
		||||
            for num, video_url in enumerate(video_urls, 1):
 | 
			
		||||
                entries.append(make_video_entry(video_id, video_url, num))
 | 
			
		||||
 | 
			
		||||
        if iframe_links:
 | 
			
		||||
            for num, iframe_link in enumerate(iframe_links, len(video_urls) + 1):
 | 
			
		||||
                entries.append(make_iframe_entry(video_id, iframe_link, num))
 | 
			
		||||
 | 
			
		||||
        playlist = common_info.copy()
 | 
			
		||||
        playlist.update(self.playlist_result(entries, video_id, title, description))
 | 
			
		||||
        return playlist
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class LifeEmbedIE(InfoExtractor):
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user