diff options
Diffstat (limited to 'youtube_dl/extractor/tunein.py')
| -rw-r--r-- | youtube_dl/extractor/tunein.py | 107 | 
1 files changed, 57 insertions, 50 deletions
| diff --git a/youtube_dl/extractor/tunein.py b/youtube_dl/extractor/tunein.py index ae4cfaec2..7e51de89e 100644 --- a/youtube_dl/extractor/tunein.py +++ b/youtube_dl/extractor/tunein.py @@ -11,6 +11,12 @@ from ..compat import compat_urlparse  class TuneInBaseIE(InfoExtractor):      _API_BASE_URL = 'http://tunein.com/tuner/tune/' +    @staticmethod +    def _extract_urls(webpage): +        return re.findall( +            r'<iframe[^>]+src=["\'](?P<url>(?:https?://)?tunein\.com/embed/player/[pst]\d+)', +            webpage) +      def _real_extract(self, url):          content_id = self._match_id(url) @@ -69,82 +75,83 @@ class TuneInClipIE(TuneInBaseIE):      _VALID_URL = r'https?://(?:www\.)?tunein\.com/station/.*?audioClipId\=(?P<id>\d+)'      _API_URL_QUERY = '?tuneType=AudioClip&audioclipId=%s' -    _TESTS = [ -        { -            'url': 'http://tunein.com/station/?stationId=246119&audioClipId=816', -            'md5': '99f00d772db70efc804385c6b47f4e77', -            'info_dict': { -                'id': '816', -                'title': '32m', -                'ext': 'mp3', -            }, +    _TESTS = [{ +        'url': 'http://tunein.com/station/?stationId=246119&audioClipId=816', +        'md5': '99f00d772db70efc804385c6b47f4e77', +        'info_dict': { +            'id': '816', +            'title': '32m', +            'ext': 'mp3',          }, -    ] +    }]  class TuneInStationIE(TuneInBaseIE):      IE_NAME = 'tunein:station' -    _VALID_URL = r'https?://(?:www\.)?tunein\.com/(?:radio/.*?-s|station/.*?StationId\=)(?P<id>\d+)' +    _VALID_URL = r'https?://(?:www\.)?tunein\.com/(?:radio/.*?-s|station/.*?StationId=|embed/player/s)(?P<id>\d+)'      _API_URL_QUERY = '?tuneType=Station&stationId=%s'      @classmethod      def suitable(cls, url):          return False if TuneInClipIE.suitable(url) else super(TuneInStationIE, cls).suitable(url) -    _TESTS = [ -        { -            'url': 'http://tunein.com/radio/Jazz24-885-s34682/', -            'info_dict': { -                'id': '34682', -                'title': 'Jazz 24 on 88.5 Jazz24 - KPLU-HD2', -                'ext': 'mp3', -                'location': 'Tacoma, WA', -            }, -            'params': { -                'skip_download': True,  # live stream -            }, +    _TESTS = [{ +        'url': 'http://tunein.com/radio/Jazz24-885-s34682/', +        'info_dict': { +            'id': '34682', +            'title': 'Jazz 24 on 88.5 Jazz24 - KPLU-HD2', +            'ext': 'mp3', +            'location': 'Tacoma, WA', +        }, +        'params': { +            'skip_download': True,  # live stream          }, -    ] +    }, { +        'url': 'http://tunein.com/embed/player/s6404/', +        'only_matching': True, +    }]  class TuneInProgramIE(TuneInBaseIE):      IE_NAME = 'tunein:program' -    _VALID_URL = r'https?://(?:www\.)?tunein\.com/(?:radio/.*?-p|program/.*?ProgramId\=)(?P<id>\d+)' +    _VALID_URL = r'https?://(?:www\.)?tunein\.com/(?:radio/.*?-p|program/.*?ProgramId=|embed/player/p)(?P<id>\d+)'      _API_URL_QUERY = '?tuneType=Program&programId=%s' -    _TESTS = [ -        { -            'url': 'http://tunein.com/radio/Jazz-24-p2506/', -            'info_dict': { -                'id': '2506', -                'title': 'Jazz 24 on 91.3 WUKY-HD3', -                'ext': 'mp3', -                'location': 'Lexington, KY', -            }, -            'params': { -                'skip_download': True,  # live stream -            }, +    _TESTS = [{ +        'url': 'http://tunein.com/radio/Jazz-24-p2506/', +        'info_dict': { +            'id': '2506', +            'title': 'Jazz 24 on 91.3 WUKY-HD3', +            'ext': 'mp3', +            'location': 'Lexington, KY',          }, -    ] +        'params': { +            'skip_download': True,  # live stream +        }, +    }, { +        'url': 'http://tunein.com/embed/player/p191660/', +        'only_matching': True, +    }]  class TuneInTopicIE(TuneInBaseIE):      IE_NAME = 'tunein:topic' -    _VALID_URL = r'https?://(?:www\.)?tunein\.com/topic/.*?TopicId\=(?P<id>\d+)' +    _VALID_URL = r'https?://(?:www\.)?tunein\.com/(?:topic/.*?TopicId=|embed/player/t)(?P<id>\d+)'      _API_URL_QUERY = '?tuneType=Topic&topicId=%s' -    _TESTS = [ -        { -            'url': 'http://tunein.com/topic/?TopicId=101830576', -            'md5': 'c31a39e6f988d188252eae7af0ef09c9', -            'info_dict': { -                'id': '101830576', -                'title': 'Votez pour moi du 29 octobre 2015 (29/10/15)', -                'ext': 'mp3', -                'location': 'Belgium', -            }, +    _TESTS = [{ +        'url': 'http://tunein.com/topic/?TopicId=101830576', +        'md5': 'c31a39e6f988d188252eae7af0ef09c9', +        'info_dict': { +            'id': '101830576', +            'title': 'Votez pour moi du 29 octobre 2015 (29/10/15)', +            'ext': 'mp3', +            'location': 'Belgium',          }, -    ] +    }, { +        'url': 'http://tunein.com/embed/player/t101830576/', +        'only_matching': True, +    }]  class TuneInShortenerIE(InfoExtractor): | 
