aboutsummaryrefslogtreecommitdiffstats
path: root/youtube_dl/extractor/vevo.py
diff options
context:
space:
mode:
authorPhilipp Hagemeister <phihag@phihag.de>2015-02-02 22:48:12 +0100
committerPhilipp Hagemeister <phihag@phihag.de>2015-02-02 22:48:12 +0100
commit7d3d06a16cb585be35c2152f4bd4cba9c32081a3 (patch)
tree360b42fb0421416b502e72fc811a8c3b9a183712 /youtube_dl/extractor/vevo.py
parentc21b1fbeeb0305fbf7804fcad9d4aa2dc6288de6 (diff)
downloadyoutube-dl-7d3d06a16cb585be35c2152f4bd4cba9c32081a3.zip
youtube-dl-7d3d06a16cb585be35c2152f4bd4cba9c32081a3.tar.gz
youtube-dl-7d3d06a16cb585be35c2152f4bd4cba9c32081a3.tar.bz2
[vevo] Restore SMIL support (#3656)
Diffstat (limited to 'youtube_dl/extractor/vevo.py')
-rw-r--r--youtube_dl/extractor/vevo.py25
1 files changed, 23 insertions, 2 deletions
diff --git a/youtube_dl/extractor/vevo.py b/youtube_dl/extractor/vevo.py
index 43f6b02..c17094f 100644
--- a/youtube_dl/extractor/vevo.py
+++ b/youtube_dl/extractor/vevo.py
@@ -9,6 +9,7 @@ from ..compat import (
)
from ..utils import (
ExtractorError,
+ int_or_none,
)
@@ -192,9 +193,29 @@ class VevoIE(InfoExtractor):
# Download via HLS API
formats.extend(self._download_api_formats(video_id))
+ # Download SMIL
+ smil_blocks = sorted((
+ f for f in video_info['videoVersions']
+ if f['sourceType'] == 13),
+ key=lambda f: f['version'])
+ smil_url = '%s/Video/V2/VFILE/%s/%sr.smil' % (
+ self._SMIL_BASE_URL, video_id, video_id.lower())
+ if smil_blocks:
+ smil_url_m = self._search_regex(
+ r'url="([^"]+)"', smil_blocks[-1]['data'], 'SMIL URL',
+ default=None)
+ if smil_url_m is not None:
+ smil_url = smil_url_m
+ if smil_url:
+ smil_xml = self._download_webpage(
+ smil_url, video_id, 'Downloading SMIL info', fatal=False)
+ if smil_xml:
+ formats.extend(self._formats_from_smil(smil_xml))
+
self._sort_formats(formats)
- timestamp_ms = int(self._search_regex(
- r'/Date\((\d+)\)/', video_info['launchDate'], 'launch date'))
+ timestamp_ms = int_or_none(self._search_regex(
+ r'/Date\((\d+)\)/',
+ video_info['launchDate'], 'launch date', fatal=False))
return {
'id': video_id,