diff options
| author | Tithen-Firion <Tithen-Firion@users.noreply.github.com> | 2017-05-04 11:00:06 +0200 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-05-04 11:00:06 +0200 | 
| commit | c89267d31ad99eb5b1a87cd354de5280a2a087b1 (patch) | |
| tree | 8bb3b01cd088d0646089344bddd3d4ff272c0065 /youtube_dl/extractor/brightcove.py | |
| parent | 7552f96352f35cd877e52fd0770b77ba1856fc62 (diff) | |
| parent | 0c265486016b06342fb257966474ce591667aaff (diff) | |
Merge branch 'master' into openload-phantomjs-method
Diffstat (limited to 'youtube_dl/extractor/brightcove.py')
| -rw-r--r-- | youtube_dl/extractor/brightcove.py | 26 | 
1 files changed, 20 insertions, 6 deletions
| diff --git a/youtube_dl/extractor/brightcove.py b/youtube_dl/extractor/brightcove.py index 124497e95..3f017a2b1 100644 --- a/youtube_dl/extractor/brightcove.py +++ b/youtube_dl/extractor/brightcove.py @@ -131,6 +131,12 @@ class BrightcoveLegacyIE(InfoExtractor):              },              'playlist_mincount': 10,          }, +        { +            # playerID inferred from bcpid +            # from http://www.un.org/chinese/News/story.asp?NewsID=27724 +            'url': 'https://link.brightcove.com/services/player/bcpid1722935254001/?bctid=5360463607001&autoStart=false&secureConnections=true&width=650&height=350', +            'only_matching': True,  # Tested in GenericIE +        }      ]      FLV_VCODECS = {          1: 'SORENSON', @@ -266,9 +272,13 @@ class BrightcoveLegacyIE(InfoExtractor):          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)])) +        matches = re.findall(r'(customBC\.createVideo\(.+?\);)', webpage) +        if matches: +            return list(filter(None, [ +                cls._build_brighcove_url_from_js(custom_bc) +                for custom_bc in matches])) +        return [src for _, src in re.findall( +            r'<iframe[^>]+src=([\'"])((?:https?:)?//link\.brightcove\.com/services/player/(?!\1).+)\1', webpage)]      def _real_extract(self, url):          url, smuggled_data = unsmuggle_url(url, {}) @@ -285,6 +295,10 @@ class BrightcoveLegacyIE(InfoExtractor):          if videoPlayer:              # We set the original url as the default 'Referer' header              referer = smuggled_data.get('Referer', url) +            if 'playerID' not in query: +                mobj = re.search(r'/bcpid(\d+)', url) +                if mobj is not None: +                    query['playerID'] = [mobj.group(1)]              return self._get_video_info(                  videoPlayer[0], query, referer=referer)          elif 'playerKey' in query: @@ -484,8 +498,8 @@ class BrightcoveNewIE(InfoExtractor):      }]      @staticmethod -    def _extract_url(webpage): -        urls = BrightcoveNewIE._extract_urls(webpage) +    def _extract_url(ie, webpage): +        urls = BrightcoveNewIE._extract_urls(ie, webpage)          return urls[0] if urls else None      @staticmethod @@ -508,7 +522,7 @@ class BrightcoveNewIE(InfoExtractor):          # [2] looks like:          for video, script_tag, account_id, player_id, embed in re.findall(                  r'''(?isx) -                    (<video\s+[^>]+>) +                    (<video\s+[^>]*\bdata-video-id\s*=\s*['"]?[^>]+>)                      (?:.*?                          (<script[^>]+                              src=["\'](?:https?:)?//players\.brightcove\.net/ | 
