diff options
author | Sergey M․ <dstftw@gmail.com> | 2015-06-13 19:54:02 +0600 |
---|---|---|
committer | Sergey M․ <dstftw@gmail.com> | 2015-06-13 19:54:02 +0600 |
commit | 49bc802f81c7939b34e48454f4606c587d9ed631 (patch) | |
tree | b59e72929b99438d9d773603bc6d2ca2d2848d3a /youtube_dl/extractor | |
parent | 78e2b74bb945dc7f1724f7486405dd523486d634 (diff) | |
parent | af9cdee9cba610aa3924f90a8a3fcd7dd43c65eb (diff) | |
download | hypervideo-pre-49bc802f81c7939b34e48454f4606c587d9ed631.tar.lz hypervideo-pre-49bc802f81c7939b34e48454f4606c587d9ed631.tar.xz hypervideo-pre-49bc802f81c7939b34e48454f4606c587d9ed631.zip |
Merge branch 'atomicdryad-brightcove_custombc_extractor'
Diffstat (limited to 'youtube_dl/extractor')
-rw-r--r-- | youtube_dl/extractor/brightcove.py | 29 |
1 files changed, 28 insertions, 1 deletions
diff --git a/youtube_dl/extractor/brightcove.py b/youtube_dl/extractor/brightcove.py index c1d4320e1..d768f99e6 100644 --- a/youtube_dl/extractor/brightcove.py +++ b/youtube_dl/extractor/brightcove.py @@ -156,6 +156,28 @@ class BrightcoveIE(InfoExtractor): linkBase = find_param('linkBaseURL') if linkBase is not None: params['linkBaseURL'] = linkBase + return cls._make_brightcove_url(params) + + @classmethod + def _build_brighcove_url_from_js(cls, object_js): + # The layout of JS is as follows: + # customBC.createVideo = function (width, height, playerID, playerKey, videoPlayer, VideoRandomID) { + # // build Brightcove <object /> XML + # } + m = re.search( + r'''(?x)customBC.\createVideo\( + .*? # skipping width and height + ["\'](?P<playerID>\d+)["\']\s*,\s* # playerID + ["\'](?P<playerKey>AQ[^"\']{48})[^"\']*["\']\s*,\s* # playerKey begins with AQ and is 50 characters + # in length, however it's appended to itself + # in places, so truncate + ["\'](?P<videoID>\d+)["\'] # @videoPlayer + ''', object_js) + if m: + return cls._make_brightcove_url(m.groupdict()) + + @classmethod + def _make_brightcove_url(cls, params): data = compat_urllib_parse.urlencode(params) return cls._FEDERATED_URL_TEMPLATE % data @@ -188,7 +210,12 @@ class BrightcoveIE(InfoExtractor): [^>]*?>\s*<param\s+name="movie"\s+value="https?://[^/]*brightcove\.com/ ).+?>\s*</object>''', webpage) - return list(filter(None, [cls._build_brighcove_url(m) for m in matches])) + if matches: + return list(filter(None, [cls._build_brighcove_url(m) for m in matches])) + + return list(filter(None, [ + cls._build_brighcove_url_from_js(custom_bc) + for custom_bc in re.findall(r'(customBC\.createVideo\(.+?\);)', webpage)])) def _real_extract(self, url): url, smuggled_data = unsmuggle_url(url, {}) |