|
|
@ -16,7 +16,8 @@ from ..utils import (
|
|
|
|
class CeskaTelevizeIE(InfoExtractor):
|
|
|
|
class CeskaTelevizeIE(InfoExtractor):
|
|
|
|
_VALID_URL = r'https?://www\.ceskatelevize\.cz/(porady|ivysilani)/(.+/)?(?P<id>[^?#]+)'
|
|
|
|
_VALID_URL = r'https?://www\.ceskatelevize\.cz/(porady|ivysilani)/(.+/)?(?P<id>[^?#]+)'
|
|
|
|
|
|
|
|
|
|
|
|
_TESTS = [{
|
|
|
|
_TESTS = [
|
|
|
|
|
|
|
|
{
|
|
|
|
'url': 'http://www.ceskatelevize.cz/ivysilani/10532695142-prvni-republika/213512120230004-spanelska-chripka',
|
|
|
|
'url': 'http://www.ceskatelevize.cz/ivysilani/10532695142-prvni-republika/213512120230004-spanelska-chripka',
|
|
|
|
'info_dict': {
|
|
|
|
'info_dict': {
|
|
|
|
'id': '213512120230004',
|
|
|
|
'id': '213512120230004',
|
|
|
@ -28,7 +29,8 @@ class CeskaTelevizeIE(InfoExtractor):
|
|
|
|
'skip_download': True, # requires rtmpdump
|
|
|
|
'skip_download': True, # requires rtmpdump
|
|
|
|
},
|
|
|
|
},
|
|
|
|
'skip': 'Works only from Czech Republic.',
|
|
|
|
'skip': 'Works only from Czech Republic.',
|
|
|
|
}, {
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
'url': 'http://www.ceskatelevize.cz/ivysilani/1030584952-tsatsiki-maminka-a-policajt',
|
|
|
|
'url': 'http://www.ceskatelevize.cz/ivysilani/1030584952-tsatsiki-maminka-a-policajt',
|
|
|
|
'info_dict': {
|
|
|
|
'info_dict': {
|
|
|
|
'id': '20138143440',
|
|
|
|
'id': '20138143440',
|
|
|
@ -40,7 +42,20 @@ class CeskaTelevizeIE(InfoExtractor):
|
|
|
|
'skip_download': True, # requires rtmpdump
|
|
|
|
'skip_download': True, # requires rtmpdump
|
|
|
|
},
|
|
|
|
},
|
|
|
|
'skip': 'Works only from Czech Republic.',
|
|
|
|
'skip': 'Works only from Czech Republic.',
|
|
|
|
}]
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
'url': 'http://www.ceskatelevize.cz/ivysilani/10532695142-prvni-republika/bonus/14716-zpevacka-z-duparny-bobina',
|
|
|
|
|
|
|
|
'info_dict': {
|
|
|
|
|
|
|
|
'id': '14716',
|
|
|
|
|
|
|
|
'ext': 'flv',
|
|
|
|
|
|
|
|
'title': 'První republika: Zpěvačka z Dupárny Bobina',
|
|
|
|
|
|
|
|
'duration': 90,
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
'params': {
|
|
|
|
|
|
|
|
'skip_download': True, # requires rtmpdump
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
def _real_extract(self, url):
|
|
|
|
def _real_extract(self, url):
|
|
|
|
url = url.replace('/porady/', '/ivysilani/').replace('/video/', '')
|
|
|
|
url = url.replace('/porady/', '/ivysilani/').replace('/video/', '')
|
|
|
@ -50,9 +65,9 @@ class CeskaTelevizeIE(InfoExtractor):
|
|
|
|
|
|
|
|
|
|
|
|
webpage = self._download_webpage(url, video_id)
|
|
|
|
webpage = self._download_webpage(url, video_id)
|
|
|
|
|
|
|
|
|
|
|
|
if '<p class="title">Chyba konfigurace prohlížeče.</p>' not in webpage:
|
|
|
|
NOT_AVAILABLE_STRING = 'This content is not available at your territory due to limited copyright.'
|
|
|
|
msg = self._html_search_regex(r'<p class="title">(.+?)</p>', webpage, 'error-message')
|
|
|
|
if '%s</p>' % NOT_AVAILABLE_STRING in webpage:
|
|
|
|
raise ExtractorError(msg.replace('<br />', ' '))
|
|
|
|
raise ExtractorError(NOT_AVAILABLE_STRING, expected=True)
|
|
|
|
|
|
|
|
|
|
|
|
typ = self._html_search_regex(r'getPlaylistUrl\(\[\{"type":"(.+?)","id":".+?"\}\],', webpage, 'type')
|
|
|
|
typ = self._html_search_regex(r'getPlaylistUrl\(\[\{"type":"(.+?)","id":".+?"\}\],', webpage, 'type')
|
|
|
|
episode_id = self._html_search_regex(r'getPlaylistUrl\(\[\{"type":".+?","id":"(.+?)"\}\],', webpage, 'episode_id')
|
|
|
|
episode_id = self._html_search_regex(r'getPlaylistUrl\(\[\{"type":".+?","id":"(.+?)"\}\],', webpage, 'episode_id')
|
|
|
|