about summary refs log tree commit diff
path: root/youtube_dl/extractor/naver.py
diff options
context:
space:
mode:
authorSergey M․ <dstftw@gmail.com>2018-03-29 23:49:09 +0700
committerSergey M․ <dstftw@gmail.com>2018-03-29 23:49:09 +0700
commit190f6c936be0ec03ed999cbf34e73f38c9beb022 (patch)
tree88f4c7ebaa9aef6a8e81ac611bbe34c43880f2e4 /youtube_dl/extractor/naver.py
parent02f6ccbce3a50d8db3eac06a5820347cf674ca86 (diff)
downloadyoutube-dl-190f6c936be0ec03ed999cbf34e73f38c9beb022.tar.gz
youtube-dl-190f6c936be0ec03ed999cbf34e73f38c9beb022.tar.xz
youtube-dl-190f6c936be0ec03ed999cbf34e73f38c9beb022.zip
[naver] Fix extraction (closes #16029)
Diffstat (limited to 'youtube_dl/extractor/naver.py')
-rw-r--r--youtube_dl/extractor/naver.py17
1 files changed, 10 insertions, 7 deletions
diff --git a/youtube_dl/extractor/naver.py b/youtube_dl/extractor/naver.py
index 2047d4402..bb3d94413 100644
--- a/youtube_dl/extractor/naver.py
+++ b/youtube_dl/extractor/naver.py
@@ -1,8 +1,6 @@
 # coding: utf-8
 from __future__ import unicode_literals
 
-import re
-
 from .common import InfoExtractor
 from ..utils import (
     ExtractorError,
@@ -43,9 +41,14 @@ class NaverIE(InfoExtractor):
         video_id = self._match_id(url)
         webpage = self._download_webpage(url, video_id)
 
-        m_id = re.search(r'var rmcPlayer = new nhn\.rmcnmv\.RMCVideoPlayer\("(.+?)", "(.+?)"',
-                         webpage)
-        if m_id is None:
+        vid = self._search_regex(
+            r'videoId["\']\s*:\s*(["\'])(?P<value>(?:(?!\1).)+)\1', webpage,
+            'video id', fatal=None, group='value')
+        in_key = self._search_regex(
+            r'inKey["\']\s*:\s*(["\'])(?P<value>(?:(?!\1).)+)\1', webpage,
+            'key', default=None, group='value')
+
+        if not vid or not in_key:
             error = self._html_search_regex(
                 r'(?s)<div class="(?:nation_error|nation_box|error_box)">\s*(?:<!--.*?-->)?\s*<p class="[^"]+">(?P<msg>.+?)</p>\s*</div>',
                 webpage, 'error', default=None)
@@ -53,9 +56,9 @@ class NaverIE(InfoExtractor):
                 raise ExtractorError(error, expected=True)
             raise ExtractorError('couldn\'t extract vid and key')
         video_data = self._download_json(
-            'http://play.rmcnmv.naver.com/vod/play/v2.0/' + m_id.group(1),
+            'http://play.rmcnmv.naver.com/vod/play/v2.0/' + vid,
             video_id, query={
-                'key': m_id.group(2),
+                'key': in_key,
             })
         meta = video_data['meta']
         title = meta['subject']