diff options
Diffstat (limited to 'youtube_dl/extractor/vimeo.py')
| -rw-r--r-- | youtube_dl/extractor/vimeo.py | 30 | 
1 files changed, 22 insertions, 8 deletions
| diff --git a/youtube_dl/extractor/vimeo.py b/youtube_dl/extractor/vimeo.py index 28bcc89cd..10d6745af 100644 --- a/youtube_dl/extractor/vimeo.py +++ b/youtube_dl/extractor/vimeo.py @@ -22,6 +22,7 @@ from ..utils import (      unified_strdate,      unsmuggle_url,      urlencode_postdata, +    unescapeHTML,  ) @@ -38,7 +39,7 @@ class VimeoBaseInfoExtractor(InfoExtractor):          self.report_login()          login_url = 'https://vimeo.com/log_in'          webpage = self._download_webpage(login_url, None, False) -        token = self._search_regex(r'xsrft = \'(.*?)\'', webpage, 'login token') +        token = self._search_regex(r'xsrft":"(.*?)"', webpage, 'login token')          data = urlencode_postdata({              'email': username,              'password': password, @@ -173,11 +174,26 @@ class VimeoIE(VimeoBaseInfoExtractor):          },      ] +    @staticmethod +    def _extract_vimeo_url(url, webpage): +        # Look for embedded (iframe) Vimeo player +        mobj = re.search( +            r'<iframe[^>]+?src=(["\'])(?P<url>(?:https?:)?//player\.vimeo\.com/video/.+?)\1', webpage) +        if mobj: +            player_url = unescapeHTML(mobj.group('url')) +            surl = smuggle_url(player_url, {'Referer': url}) +            return surl +        # Look for embedded (swf embed) Vimeo player +        mobj = re.search( +            r'<embed[^>]+?src="((?:https?:)?//(?:www\.)?vimeo\.com/moogaloop\.swf.+?)"', webpage) +        if mobj: +            return mobj.group(1) +      def _verify_video_password(self, url, video_id, webpage):          password = self._downloader.params.get('videopassword', None)          if password is None:              raise ExtractorError('This video is protected by a password, use the --video-password option', expected=True) -        token = self._search_regex(r'xsrft = \'(.*?)\'', webpage, 'login token') +        token = self._search_regex(r'xsrft[\s=:"\']+([^"\']+)', webpage, 'login token')          data = urlencode_postdata({              'password': password,              'token': token, @@ -223,6 +239,8 @@ class VimeoIE(VimeoBaseInfoExtractor):          orig_url = url          if mobj.group('pro') or mobj.group('player'):              url = 'https://player.vimeo.com/video/' + video_id +        else: +            url = 'https://vimeo.com/' + video_id          # Retrieve video webpage to extract further information          request = compat_urllib_request.Request(url, None, headers) @@ -434,12 +452,8 @@ class VimeoChannelIE(InfoExtractor):          password = self._downloader.params.get('videopassword', None)          if password is None:              raise ExtractorError('This album is protected by a password, use the --video-password option', expected=True) -        fields = dict(re.findall(r'''(?x)<input\s+ -            type="hidden"\s+ -            name="([^"]+)"\s+ -            value="([^"]*)" -            ''', login_form)) -        token = self._search_regex(r'xsrft = \'(.*?)\'', webpage, 'login token') +        fields = self._hidden_inputs(login_form) +        token = self._search_regex(r'xsrft[\s=:"\']+([^"\']+)', webpage, 'login token')          fields['token'] = token          fields['password'] = password          post = urlencode_postdata(fields) | 
