|
|
@ -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)) |
|
|
|