diff options
Diffstat (limited to 'youtube_dl/extractor/vlive.py')
| -rw-r--r-- | youtube_dl/extractor/vlive.py | 30 | 
1 files changed, 8 insertions, 22 deletions
| diff --git a/youtube_dl/extractor/vlive.py b/youtube_dl/extractor/vlive.py index a672ea9c5..8d671cca7 100644 --- a/youtube_dl/extractor/vlive.py +++ b/youtube_dl/extractor/vlive.py @@ -1,8 +1,7 @@  # coding: utf-8 -from __future__ import division, unicode_literals +from __future__ import unicode_literals  import re -import time  from .common import InfoExtractor  from ..utils import ( @@ -10,6 +9,7 @@ from ..utils import (      ExtractorError,      float_or_none,      int_or_none, +    remove_start,  )  from ..compat import compat_urllib_parse_urlencode @@ -23,7 +23,7 @@ class VLiveIE(InfoExtractor):          'info_dict': {              'id': '1326',              'ext': 'mp4', -            'title': "[V] Girl's Day's Broadcast", +            'title': "[V LIVE] Girl's Day's Broadcast",              'creator': "Girl's Day",              'view_count': int,          }, @@ -35,24 +35,12 @@ class VLiveIE(InfoExtractor):          webpage = self._download_webpage(              'http://www.vlive.tv/video/%s' % video_id, video_id) -        # UTC+x - UTC+9 (KST) -        tz = time.altzone if time.localtime().tm_isdst == 1 else time.timezone -        tz_offset = -tz // 60 - 9 * 60 -        self._set_cookie('vlive.tv', 'timezoneOffset', '%d' % tz_offset) - -        status_params = self._download_json( -            'http://www.vlive.tv/video/status?videoSeq=%s' % video_id, -            video_id, 'Downloading JSON status', -            headers={'Referer': url.encode('utf-8')}) -        status = status_params.get('status') -        air_start = status_params.get('onAirStartAt', '') -        is_live = status_params.get('isLive') -          video_params = self._search_regex( -            r'vlive\.tv\.video\.ajax\.request\.handler\.init\((.+)\)', +            r'\bvlive\.video\.init\(([^)]+)\)',              webpage, 'video params') -        live_params, long_video_id, key = re.split( -            r'"\s*,\s*"', video_params)[1:4] +        status, _, _, live_params, long_video_id, key = re.split( +            r'"\s*,\s*"', video_params)[2:8] +        status = remove_start(status, 'PRODUCT_')          if status == 'LIVE_ON_AIR' or status == 'BIG_EVENT_ON_AIR':              live_params = self._parse_json('"%s"' % live_params, video_id) @@ -61,8 +49,6 @@ class VLiveIE(InfoExtractor):          elif status == 'VOD_ON_AIR' or status == 'BIG_EVENT_INTRO':              if long_video_id and key:                  return self._replay(video_id, webpage, long_video_id, key) -            elif is_live: -                status = 'LIVE_END'              else:                  status = 'COMING_SOON' @@ -70,7 +56,7 @@ class VLiveIE(InfoExtractor):              raise ExtractorError('Uploading for replay. Please wait...',                                   expected=True)          elif status == 'COMING_SOON': -            raise ExtractorError('Coming soon! %s' % air_start, expected=True) +            raise ExtractorError('Coming soon!', expected=True)          elif status == 'CANCELED':              raise ExtractorError('We are sorry, '                                   'but the live broadcast has been canceled.', | 
