Skip to content

Commit

Permalink
[slideslive] add support for url and vimeo service names(closes #23414)
Browse files Browse the repository at this point in the history
  • Loading branch information
remitamine authored and pareronia committed Jun 22, 2020
1 parent ecfa385 commit c848766
Showing 1 changed file with 27 additions and 12 deletions.
39 changes: 27 additions & 12 deletions youtube_dl/extractor/slideslive.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from __future__ import unicode_literals

from .common import InfoExtractor
from ..utils import ExtractorError
from ..utils import smuggle_url


class SlidesLiveIE(InfoExtractor):
Expand All @@ -24,23 +24,38 @@ class SlidesLiveIE(InfoExtractor):
# video_service_name = youtube
'url': 'https://slideslive.com/38903721/magic-a-scientific-resurrection-of-an-esoteric-legend',
'only_matching': True,
}, {
# video_service_name = url
'url': 'https://slideslive.com/38922070/learning-transferable-skills-1',
'only_matching': True,
}, {
# video_service_name = vimeo
'url': 'https://slideslive.com/38921896/retrospectives-a-venue-for-selfreflection-in-ml-research-3',
'only_matching': True,
}]

def _real_extract(self, url):
video_id = self._match_id(url)
video_data = self._download_json(
'https://ben.slideslive.com/player/' + video_id, video_id)
service_name = video_data['video_service_name'].lower()
if service_name == 'youtube':
yt_video_id = video_data['video_service_id']
return {
assert service_name in ('url', 'vimeo', 'youtube')
service_id = video_data['video_service_id']
info = {
'id': video_id,
'thumbnail': video_data.get('thumbnail'),
'url': service_id,
}
if service_name == 'url':
info['title'] = video_data['title']
else:
info.update({
'_type': 'url_transparent',
'ie_key': 'Youtube',
'id': yt_video_id,
'thumbnail': video_data.get('thumbnail'),
'ie_key': service_name.capitalize(),
'title': video_data.get('title'),
'url': yt_video_id,
}
else:
raise ExtractorError(
'Unsupported service name: {0}'.format(service_name), expected=True)
})
if service_name == 'vimeo':
info['url'] = smuggle_url(
'https://player.vimeo.com/video/' + service_id,
{'http_headers': {'Referer': url}})
return info

0 comments on commit c848766

Please sign in to comment.