aboutsummaryrefslogtreecommitdiff
path: root/youtube_dl/extractor/vessel.py
diff options
context:
space:
mode:
authorSergey M․ <dstftw@gmail.com>2016-06-09 04:00:47 +0700
committerSergey M․ <dstftw@gmail.com>2016-06-09 04:00:47 +0700
commit11380753b5aa9d8128ef28a968ab325973276fa5 (patch)
tree6741148566d255272101dd40a14515378b1c94d9 /youtube_dl/extractor/vessel.py
parent411c590a1f997f9efd71be8f434821acbf33a35f (diff)
downloadyoutube-dl-11380753b5aa9d8128ef28a968ab325973276fa5.tar.xz
[vessel] Add support for embed urls and improve extraction
Diffstat (limited to 'youtube_dl/extractor/vessel.py')
-rw-r--r--youtube_dl/extractor/vessel.py27
1 files changed, 20 insertions, 7 deletions
diff --git a/youtube_dl/extractor/vessel.py b/youtube_dl/extractor/vessel.py
index 1a0ff3395..e027c018b 100644
--- a/youtube_dl/extractor/vessel.py
+++ b/youtube_dl/extractor/vessel.py
@@ -2,6 +2,7 @@
from __future__ import unicode_literals
import json
+import re
from .common import InfoExtractor
from ..utils import (
@@ -12,11 +13,11 @@ from ..utils import (
class VesselIE(InfoExtractor):
- _VALID_URL = r'https?://(?:www\.)?vessel\.com/videos/(?P<id>[0-9a-zA-Z]+)'
+ _VALID_URL = r'https?://(?:www\.)?vessel\.com/(?:videos|embed)/(?P<id>[0-9a-zA-Z]+)'
_API_URL_TEMPLATE = 'https://www.vessel.com/api/view/items/%s'
_LOGIN_URL = 'https://www.vessel.com/api/account/login'
_NETRC_MACHINE = 'vessel'
- _TEST = {
+ _TESTS = [{
'url': 'https://www.vessel.com/videos/HDN7G5UMs',
'md5': '455cdf8beb71c6dd797fd2f3818d05c4',
'info_dict': {
@@ -28,7 +29,16 @@ class VesselIE(InfoExtractor):
'description': 'Did Nvidia pull out all the stops on the Titan X, or does its performance leave something to be desired?',
'timestamp': int,
},
- }
+ }, {
+ 'url': 'https://www.vessel.com/embed/G4U7gUJ6a?w=615&h=346',
+ 'only_matching': True,
+ }]
+
+ @staticmethod
+ def _extract_urls(webpage):
+ return [url for _, url in re.findall(
+ r'<iframe[^>]+src=(["\'])((?:https?:)?//(?:www\.)?vessel\.com/embed/[0-9a-zA-Z]+.*?)\1',
+ webpage)]
@staticmethod
def make_json_request(url, data):
@@ -98,16 +108,19 @@ class VesselIE(InfoExtractor):
formats = []
for f in video_asset.get('sources', []):
- if f['name'] == 'hls-index':
+ location = f.get('location')
+ if not location:
+ continue
+ if f.get('name') == 'hls-index':
formats.extend(self._extract_m3u8_formats(
- f['location'], video_id, ext='mp4', m3u8_id='m3u8'))
+ location, video_id, ext='mp4', m3u8_id='m3u8'))
else:
formats.append({
- 'format_id': f['name'],
+ 'format_id': f.get('name'),
'tbr': f.get('bitrate'),
'height': f.get('height'),
'width': f.get('width'),
- 'url': f['location'],
+ 'url': location,
})
self._sort_formats(formats)