1
mirror of https://github.com/yt-dlp/yt-dlp synced 2024-12-31 01:46:24 +01:00
yt-dlp/youtube_dl/extractor/vice.py

41 lines
1.4 KiB
Python
Raw Normal View History

from __future__ import unicode_literals
from .common import InfoExtractor
from .ooyala import OoyalaIE
from ..utils import ExtractorError
class ViceIE(InfoExtractor):
2015-07-19 20:42:25 +02:00
_VALID_URL = r'https?://(?:.+?\.)?vice\.com/(?:[^/]+/)+(?P<id>.+)'
2015-07-19 18:31:38 +02:00
_TESTS = [
{
'url': 'http://www.vice.com/Fringes/cowboy-capitalists-part-1',
'info_dict': {
'id': '43cW1mYzpia9IlestBjVpd23Yu3afAfp',
'ext': 'mp4',
'title': 'VICE_COWBOYCAPITALISTS_PART01_v1_VICE_WM_1080p.mov',
2015-12-04 16:18:02 +01:00
'duration': 725.983,
2015-07-19 18:31:38 +02:00
},
'params': {
# Requires ffmpeg (m3u8 manifest)
'skip_download': True,
},
}, {
'url': 'https://news.vice.com/video/experimenting-on-animals-inside-the-monkey-lab',
2015-07-19 20:40:43 +02:00
'only_matching': True,
2015-07-19 18:31:38 +02:00
}
]
def _real_extract(self, url):
2015-07-19 20:42:25 +02:00
video_id = self._match_id(url)
webpage = self._download_webpage(url, video_id)
try:
embed_code = self._search_regex(
r'embedCode=([^&\'"]+)', webpage,
'ooyala embed code')
ooyala_url = OoyalaIE._url_for_embed_code(embed_code)
except ExtractorError:
raise ExtractorError('The page doesn\'t contain a video', expected=True)
return self.url_result(ooyala_url, ie='Ooyala')