|
|
@ -10,9 +10,9 @@ from ..utils import (
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class AudiMediaIE(InfoExtractor):
|
|
|
|
class AudiMediaIE(InfoExtractor):
|
|
|
|
_VALID_URL = r'https?://(?:www\.)?audimedia\.tv/(?:en|de)/vid/(?P<id>[^/?#]+)'
|
|
|
|
_VALID_URL = r'https?://(?:www\.)?audi-mediacenter\.com/(?:en|de)/audimediatv/(?P<id>[^/?#]+)'
|
|
|
|
_TEST = {
|
|
|
|
_TEST = {
|
|
|
|
'url': 'https://audimedia.tv/en/vid/60-seconds-of-audi-sport-104-2015-wec-bahrain-rookie-test',
|
|
|
|
'url': 'https://www.audi-mediacenter.com/en/audimediatv/60-seconds-of-audi-sport-104-2015-wec-bahrain-rookie-test-1467',
|
|
|
|
'md5': '79a8b71c46d49042609795ab59779b66',
|
|
|
|
'md5': '79a8b71c46d49042609795ab59779b66',
|
|
|
|
'info_dict': {
|
|
|
|
'info_dict': {
|
|
|
|
'id': '1565',
|
|
|
|
'id': '1565',
|
|
|
@ -32,7 +32,10 @@ class AudiMediaIE(InfoExtractor):
|
|
|
|
display_id = self._match_id(url)
|
|
|
|
display_id = self._match_id(url)
|
|
|
|
webpage = self._download_webpage(url, display_id)
|
|
|
|
webpage = self._download_webpage(url, display_id)
|
|
|
|
|
|
|
|
|
|
|
|
raw_payload = self._search_regex(r'<script[^>]+class="amtv-embed"[^>]+id="([^"]+)"', webpage, 'raw payload')
|
|
|
|
raw_payload = self._search_regex([
|
|
|
|
|
|
|
|
r'class="amtv-embed"[^>]+id="([^"]+)"',
|
|
|
|
|
|
|
|
r'class=\\"amtv-embed\\"[^>]+id=\\"([^"]+)\\"',
|
|
|
|
|
|
|
|
], webpage, 'raw payload')
|
|
|
|
_, stage_mode, video_id, lang = raw_payload.split('-')
|
|
|
|
_, stage_mode, video_id, lang = raw_payload.split('-')
|
|
|
|
|
|
|
|
|
|
|
|
# TODO: handle s and e stage_mode (live streams and ended live streams)
|
|
|
|
# TODO: handle s and e stage_mode (live streams and ended live streams)
|
|
|
@ -59,13 +62,19 @@ class AudiMediaIE(InfoExtractor):
|
|
|
|
video_version_url = video_version.get('download_url') or video_version.get('stream_url')
|
|
|
|
video_version_url = video_version.get('download_url') or video_version.get('stream_url')
|
|
|
|
if not video_version_url:
|
|
|
|
if not video_version_url:
|
|
|
|
continue
|
|
|
|
continue
|
|
|
|
formats.append({
|
|
|
|
f = {
|
|
|
|
'url': video_version_url,
|
|
|
|
'url': video_version_url,
|
|
|
|
'width': int_or_none(video_version.get('width')),
|
|
|
|
'width': int_or_none(video_version.get('width')),
|
|
|
|
'height': int_or_none(video_version.get('height')),
|
|
|
|
'height': int_or_none(video_version.get('height')),
|
|
|
|
'abr': int_or_none(video_version.get('audio_bitrate')),
|
|
|
|
'abr': int_or_none(video_version.get('audio_bitrate')),
|
|
|
|
'vbr': int_or_none(video_version.get('video_bitrate')),
|
|
|
|
'vbr': int_or_none(video_version.get('video_bitrate')),
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
bitrate = self._search_regex(r'(\d+)k', video_version_url, 'bitrate', default=None)
|
|
|
|
|
|
|
|
if bitrate:
|
|
|
|
|
|
|
|
f.update({
|
|
|
|
|
|
|
|
'format_id': 'http-%s' % bitrate,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
formats.append(f)
|
|
|
|
self._sort_formats(formats)
|
|
|
|
self._sort_formats(formats)
|
|
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
return {
|
|
|
|