|
|
|
@ -116,16 +116,16 @@ class CondeNastIE(InfoExtractor):
|
|
|
|
|
entries = [self.url_result(build_url(path), 'CondeNast') for path in paths]
|
|
|
|
|
return self.playlist_result(entries, playlist_title=title)
|
|
|
|
|
|
|
|
|
|
def _extract_video_params(self, webpage):
|
|
|
|
|
query = {}
|
|
|
|
|
params = self._search_regex(
|
|
|
|
|
r'(?s)var params = {(.+?)}[;,]', webpage, 'player params', default=None)
|
|
|
|
|
if params:
|
|
|
|
|
query.update({
|
|
|
|
|
'videoId': self._search_regex(r'videoId: [\'"](.+?)[\'"]', params, 'video id'),
|
|
|
|
|
'playerId': self._search_regex(r'playerId: [\'"](.+?)[\'"]', params, 'player id'),
|
|
|
|
|
'target': self._search_regex(r'target: [\'"](.+?)[\'"]', params, 'target'),
|
|
|
|
|
})
|
|
|
|
|
def _extract_video_params(self, webpage, display_id):
|
|
|
|
|
query = self._parse_json(
|
|
|
|
|
self._search_regex(
|
|
|
|
|
r'(?s)var\s+params\s*=\s*({.+?})[;,]', webpage, 'player params',
|
|
|
|
|
default='{}'),
|
|
|
|
|
display_id, transform_source=js_to_json, fatal=False)
|
|
|
|
|
if query:
|
|
|
|
|
query['videoId'] = self._search_regex(
|
|
|
|
|
r'(?:data-video-id=|currentVideoId\s*=\s*)["\']([\da-f]+)',
|
|
|
|
|
webpage, 'video id', default=None)
|
|
|
|
|
else:
|
|
|
|
|
params = extract_attributes(self._search_regex(
|
|
|
|
|
r'(<[^>]+data-js="video-player"[^>]+>)',
|
|
|
|
@ -141,17 +141,27 @@ class CondeNastIE(InfoExtractor):
|
|
|
|
|
video_id = params['videoId']
|
|
|
|
|
|
|
|
|
|
video_info = None
|
|
|
|
|
if params.get('playerId'):
|
|
|
|
|
info_page = self._download_json(
|
|
|
|
|
'http://player.cnevids.com/player/video.js',
|
|
|
|
|
video_id, 'Downloading video info', fatal=False, query=params)
|
|
|
|
|
if info_page:
|
|
|
|
|
video_info = info_page.get('video')
|
|
|
|
|
if not video_info:
|
|
|
|
|
info_page = self._download_webpage(
|
|
|
|
|
'http://player.cnevids.com/player/loader.js',
|
|
|
|
|
video_id, 'Downloading loader info', query=params)
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
|
|
# New API path
|
|
|
|
|
query = params.copy()
|
|
|
|
|
query['embedType'] = 'inline'
|
|
|
|
|
info_page = self._download_json(
|
|
|
|
|
'http://player.cnevids.com/embed-api.json', video_id,
|
|
|
|
|
'Downloading embed info', fatal=False, query=query)
|
|
|
|
|
|
|
|
|
|
# Old fallbacks
|
|
|
|
|
if not info_page:
|
|
|
|
|
if params.get('playerId'):
|
|
|
|
|
info_page = self._download_json(
|
|
|
|
|
'http://player.cnevids.com/player/video.js', video_id,
|
|
|
|
|
'Downloading video info', fatal=False, query=params)
|
|
|
|
|
if info_page:
|
|
|
|
|
video_info = info_page.get('video')
|
|
|
|
|
if not video_info:
|
|
|
|
|
info_page = self._download_webpage(
|
|
|
|
|
'http://player.cnevids.com/player/loader.js',
|
|
|
|
|
video_id, 'Downloading loader info', query=params)
|
|
|
|
|
if not video_info:
|
|
|
|
|
info_page = self._download_webpage(
|
|
|
|
|
'https://player.cnevids.com/inline/video/%s.js' % video_id,
|
|
|
|
|
video_id, 'Downloading inline info', query={
|
|
|
|
@ -215,7 +225,7 @@ class CondeNastIE(InfoExtractor):
|
|
|
|
|
if url_type == 'series':
|
|
|
|
|
return self._extract_series(url, webpage)
|
|
|
|
|
else:
|
|
|
|
|
params = self._extract_video_params(webpage)
|
|
|
|
|
params = self._extract_video_params(webpage, display_id)
|
|
|
|
|
info = self._search_json_ld(
|
|
|
|
|
webpage, display_id, fatal=False)
|
|
|
|
|
info.update(self._extract_video(params))
|
|
|
|
|