diff options
| author | Jaime Marquínez Ferrándiz <jaime.marquinez.ferrandiz@gmail.com> | 2014-03-08 22:06:28 +0100 | 
|---|---|---|
| committer | Jaime Marquínez Ferrándiz <jaime.marquinez.ferrandiz@gmail.com> | 2014-03-08 22:09:42 +0100 | 
| commit | 0ef68e04d9f612ab354724f18e833201fb8bab2f (patch) | |
| tree | 776cec3ba97b3673c172f32f5faf21d736d482b8 | |
| parent | a496524db27a7c8ea901a5fe9b55c142870a54c2 (diff) | |
[mtv] Transform the urls from the mobile version to get the best quality
And don't report a warning, just log a message, it allows to pass the test from Europe.
| -rw-r--r-- | youtube_dl/extractor/mtv.py | 14 | 
1 files changed, 10 insertions, 4 deletions
| diff --git a/youtube_dl/extractor/mtv.py b/youtube_dl/extractor/mtv.py index 652054b63..d75241d3f 100644 --- a/youtube_dl/extractor/mtv.py +++ b/youtube_dl/extractor/mtv.py @@ -9,6 +9,7 @@ from ..utils import (      ExtractorError,      find_xpath_attr,      fix_xml_ampersands, +    HEADRequest,      unescapeHTML,      url_basename,      RegexNotFoundError, @@ -49,14 +50,19 @@ class MTVServicesInfoExtractor(InfoExtractor):          req.add_header('Youtubedl-user-agent', 'curl/7')          webpage = self._download_webpage(req, mtvn_id,              'Downloading mobile page') -        url = unescapeHTML(self._search_regex(r'<a href="(http://metrics.+?)"', webpage, 'url')) -        return [{'url': url,'ext': 'mp4',}] +        metrics_url = unescapeHTML(self._search_regex(r'<a href="(http://metrics.+?)"', webpage, 'url')) +        req = HEADRequest(metrics_url) +        response = self._request_webpage(req, mtvn_id, 'Resolving url') +        url = response.geturl() +        # Transform the url to get the best quality: +        url = re.sub(r'.+pxE=mp4', 'http://mtvnmobile.vo.llnwd.net/kip0/_pxn=0+_pxK=18639+_pxE=mp4', url, 1) +        return [{'url': url,'ext': 'mp4'}]      def _extract_video_formats(self, mdoc, mtvn_id):          if re.match(r'.*/(error_country_block\.swf|geoblock\.mp4)$', mdoc.find('.//src').text) is not None:              if mtvn_id is not None and self._MOBILE_TEMPLATE is not None: -                self._downloader.report_warning('The normal version is not ' -                    'available from your country, trying with the mobile version') +                self.to_screen('The normal version is not available from your ' +                    'country, trying with the mobile version')                  return self._extract_mobile_video_formats(mtvn_id)              raise ExtractorError('This video is not available from your country.',                  expected=True) | 
