|
|
@ -3,7 +3,6 @@ from __future__ import unicode_literals
|
|
|
|
import re
|
|
|
|
import re
|
|
|
|
|
|
|
|
|
|
|
|
from .common import InfoExtractor
|
|
|
|
from .common import InfoExtractor
|
|
|
|
from .subtitles import SubtitlesInfoExtractor
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
from ..compat import (
|
|
|
|
from ..compat import (
|
|
|
|
compat_str,
|
|
|
|
compat_str,
|
|
|
@ -18,7 +17,7 @@ from ..utils import (
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class BlipTVIE(SubtitlesInfoExtractor):
|
|
|
|
class BlipTVIE(InfoExtractor):
|
|
|
|
_VALID_URL = r'https?://(?:\w+\.)?blip\.tv/(?:(?:.+-|rss/flash/)(?P<id>\d+)|((?:play/|api\.swf#)(?P<lookup_id>[\da-zA-Z+_]+)))'
|
|
|
|
_VALID_URL = r'https?://(?:\w+\.)?blip\.tv/(?:(?:.+-|rss/flash/)(?P<id>\d+)|((?:play/|api\.swf#)(?P<lookup_id>[\da-zA-Z+_]+)))'
|
|
|
|
|
|
|
|
|
|
|
|
_TESTS = [
|
|
|
|
_TESTS = [
|
|
|
@ -143,7 +142,7 @@ class BlipTVIE(SubtitlesInfoExtractor):
|
|
|
|
categories = [category.text for category in item.findall('category')]
|
|
|
|
categories = [category.text for category in item.findall('category')]
|
|
|
|
|
|
|
|
|
|
|
|
formats = []
|
|
|
|
formats = []
|
|
|
|
subtitles = {}
|
|
|
|
subtitles_urls = {}
|
|
|
|
|
|
|
|
|
|
|
|
media_group = item.find(media('group'))
|
|
|
|
media_group = item.find(media('group'))
|
|
|
|
for media_content in media_group.findall(media('content')):
|
|
|
|
for media_content in media_group.findall(media('content')):
|
|
|
@ -161,7 +160,7 @@ class BlipTVIE(SubtitlesInfoExtractor):
|
|
|
|
}
|
|
|
|
}
|
|
|
|
lang = role.rpartition('-')[-1].strip().lower()
|
|
|
|
lang = role.rpartition('-')[-1].strip().lower()
|
|
|
|
langcode = LANGS.get(lang, lang)
|
|
|
|
langcode = LANGS.get(lang, lang)
|
|
|
|
subtitles[langcode] = url
|
|
|
|
subtitles_urls[langcode] = url
|
|
|
|
elif media_type.startswith('video/'):
|
|
|
|
elif media_type.startswith('video/'):
|
|
|
|
formats.append({
|
|
|
|
formats.append({
|
|
|
|
'url': real_url,
|
|
|
|
'url': real_url,
|
|
|
@ -175,11 +174,7 @@ class BlipTVIE(SubtitlesInfoExtractor):
|
|
|
|
})
|
|
|
|
})
|
|
|
|
self._sort_formats(formats)
|
|
|
|
self._sort_formats(formats)
|
|
|
|
|
|
|
|
|
|
|
|
# subtitles
|
|
|
|
subtitles = self.extract_subtitles(video_id, subtitles_urls)
|
|
|
|
video_subtitles = self.extract_subtitles(video_id, subtitles)
|
|
|
|
|
|
|
|
if self._downloader.params.get('listsubtitles', False):
|
|
|
|
|
|
|
|
self._list_available_subtitles(video_id, subtitles)
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
return {
|
|
|
|
'id': video_id,
|
|
|
|
'id': video_id,
|
|
|
@ -192,15 +187,22 @@ class BlipTVIE(SubtitlesInfoExtractor):
|
|
|
|
'thumbnail': thumbnail,
|
|
|
|
'thumbnail': thumbnail,
|
|
|
|
'categories': categories,
|
|
|
|
'categories': categories,
|
|
|
|
'formats': formats,
|
|
|
|
'formats': formats,
|
|
|
|
'subtitles': video_subtitles,
|
|
|
|
'subtitles': subtitles,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
def _download_subtitle_url(self, sub_lang, url):
|
|
|
|
def _get_subtitles(self, video_id, subtitles_urls):
|
|
|
|
# For some weird reason, blip.tv serves a video instead of subtitles
|
|
|
|
subtitles = {}
|
|
|
|
# when we request with a common UA
|
|
|
|
for lang, url in subtitles_urls.items():
|
|
|
|
req = compat_urllib_request.Request(url)
|
|
|
|
# For some weird reason, blip.tv serves a video instead of subtitles
|
|
|
|
req.add_header('User-Agent', 'youtube-dl')
|
|
|
|
# when we request with a common UA
|
|
|
|
return self._download_webpage(req, None, note=False)
|
|
|
|
req = compat_urllib_request.Request(url)
|
|
|
|
|
|
|
|
req.add_header('User-Agent', 'youtube-dl')
|
|
|
|
|
|
|
|
subtitles[lang] = [{
|
|
|
|
|
|
|
|
# The extension is 'srt' but it's actually an 'ass' file
|
|
|
|
|
|
|
|
'ext': 'ass',
|
|
|
|
|
|
|
|
'data': self._download_webpage(req, None, note=False),
|
|
|
|
|
|
|
|
}]
|
|
|
|
|
|
|
|
return subtitles
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class BlipTVUserIE(InfoExtractor):
|
|
|
|
class BlipTVUserIE(InfoExtractor):
|
|
|
|