aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSergey M․ <dstftw@gmail.com>2016-12-14 21:05:50 +0700
committerSergey M․ <dstftw@gmail.com>2016-12-14 21:05:50 +0700
commit89c63cc5f88d4ec0fbeecbec43d5bc12b8144049 (patch)
tree5dc574dd3cd1449a1815157d1d2517daee606abd
parent577748075bf5bb2f3fcf4f6b8dbb54ae4e6af585 (diff)
[vlive] Add video params extraction fallback and improve (closes #11375)
-rw-r--r--youtube_dl/extractor/vlive.py24
1 files changed, 17 insertions, 7 deletions
diff --git a/youtube_dl/extractor/vlive.py b/youtube_dl/extractor/vlive.py
index 1a9f10eb4..a6e60c88a 100644
--- a/youtube_dl/extractor/vlive.py
+++ b/youtube_dl/extractor/vlive.py
@@ -10,6 +10,7 @@ from ..utils import (
float_or_none,
int_or_none,
remove_start,
+ urlencode_postdata,
)
from ..compat import compat_urllib_parse_urlencode
@@ -48,12 +49,19 @@ class VLiveIE(InfoExtractor):
webpage = self._download_webpage(
'http://www.vlive.tv/video/%s' % video_id, video_id)
- video_params = self._parse_json(self._search_regex(
- r'\bvlive\.video\.init\(([^)]+)\);',
- webpage, 'video params'), video_id,
- transform_source=lambda s: '[' + s + ']')
+ VIDEO_PARAMS_RE = r'\bvlive\.video\.init\(([^)]+)'
+ VIDEO_PARAMS_FIELD = 'video params'
- status, long_video_id, key = video_params[2], video_params[5], video_params[6]
+ params = self._parse_json(self._search_regex(
+ VIDEO_PARAMS_RE, webpage, VIDEO_PARAMS_FIELD, default=''), video_id,
+ transform_source=lambda s: '[' + s + ']', fatal=False)
+
+ if not params or len(params) < 7:
+ params = self._search_regex(
+ VIDEO_PARAMS_RE, webpage, VIDEO_PARAMS_FIELD)
+ params = [p.strip(r'"') for p in re.split(r'\s*,\s*', params)]
+
+ status, long_video_id, key = params[2], params[5], params[6]
status = remove_start(status, 'PRODUCT_')
if status == 'LIVE_ON_AIR' or status == 'BIG_EVENT_ON_AIR':
@@ -91,14 +99,16 @@ class VLiveIE(InfoExtractor):
def _live(self, video_id, webpage):
init_page = self._download_webpage(
'http://www.vlive.tv/video/init/view',
- video_id, data="videoSeq=%s" % video_id, headers={
+ video_id, note='Downloading live webpage',
+ data=urlencode_postdata({'videoSeq': video_id}),
+ headers={
'Referer': 'http://www.vlive.tv/video/%s' % video_id,
'Content-Type': 'application/x-www-form-urlencoded'
})
live_params = self._search_regex(
r'"liveStreamInfo"\s*:\s*(".*"),',
- init_page, 'video params')
+ init_page, 'live stream info')
live_params = self._parse_json(live_params, video_id)
live_params = self._parse_json(live_params, video_id)