diff options
| author | Sergey M․ <dstftw@gmail.com> | 2015-12-01 18:35:24 +0600 | 
|---|---|---|
| committer | Sergey M․ <dstftw@gmail.com> | 2015-12-01 18:35:24 +0600 | 
| commit | 874ae0354e96a578dc44846fffd91b01079ccf1e (patch) | |
| tree | af2a68e7083955f6bf1e3086f019f4618a9c6a27 | |
| parent | 4c6b4764f0260808d321cfb6cca1daa5e3eb13d0 (diff) | |
[nrk] Extract f4m formats and impose geo restriction only when not media URL (Closes #7715)
| -rw-r--r-- | youtube_dl/extractor/nrk.py | 24 | 
1 files changed, 17 insertions, 7 deletions
| diff --git a/youtube_dl/extractor/nrk.py b/youtube_dl/extractor/nrk.py index 8ac38a174..6ff13050d 100644 --- a/youtube_dl/extractor/nrk.py +++ b/youtube_dl/extractor/nrk.py @@ -6,6 +6,7 @@ import re  from .common import InfoExtractor  from ..compat import compat_urlparse  from ..utils import ( +    determine_ext,      ExtractorError,      float_or_none,      parse_duration, @@ -48,12 +49,22 @@ class NRKIE(InfoExtractor):              'http://v8.psapi.nrk.no/mediaelement/%s' % video_id,              video_id, 'Downloading media JSON') -        if data['usageRights']['isGeoBlocked']: -            raise ExtractorError( -                'NRK har ikke rettigheter til å vise dette programmet utenfor Norge', -                expected=True) +        media_url = data.get('mediaUrl') -        video_url = data['mediaUrl'] + '?hdcore=3.5.0&plugin=aasp-3.5.0.151.81' +        if not media_url: +            if data['usageRights']['isGeoBlocked']: +                raise ExtractorError( +                    'NRK har ikke rettigheter til å vise dette programmet utenfor Norge', +                    expected=True) + +        if determine_ext(media_url) == 'f4m': +            formats = self._extract_f4m_formats( +                media_url + '?hdcore=3.5.0&plugin=aasp-3.5.0.151.81', video_id, f4m_id='hds') +        else: +            formats = [{ +                'url': media_url, +                'ext': 'flv', +            }]          duration = parse_duration(data.get('duration')) @@ -67,12 +78,11 @@ class NRKIE(InfoExtractor):          return {              'id': video_id, -            'url': video_url, -            'ext': 'flv',              'title': data['title'],              'description': data['description'],              'duration': duration,              'thumbnail': thumbnail, +            'formats': formats,          } | 
