[adobeconnect] Add new extractor(closes #20283)
parent
313e8b2b18
commit
f8987163fb
2 changed files with 38 additions and 0 deletions
@ -0,0 +1,37 @@ |
||||
# coding: utf-8 |
||||
from __future__ import unicode_literals |
||||
|
||||
from .common import InfoExtractor |
||||
from ..compat import ( |
||||
compat_parse_qs, |
||||
compat_urlparse, |
||||
) |
||||
|
||||
|
||||
class AdobeConnectIE(InfoExtractor): |
||||
_VALID_URL = r'https?://\w+\.adobeconnect\.com/(?P<id>[\w-]+)' |
||||
|
||||
def _real_extract(self, url): |
||||
video_id = self._match_id(url) |
||||
webpage = self._download_webpage(url, video_id) |
||||
title = self._html_search_regex(r'<title>(.+?)</title>', webpage, 'title') |
||||
qs = compat_parse_qs(self._search_regex(r"swfUrl\s*=\s*'([^']+)'", webpage, 'swf url').split('?')[1]) |
||||
is_live = qs.get('isLive', ['false'])[0] == 'true' |
||||
formats = [] |
||||
for con_string in qs['conStrings'][0].split(','): |
||||
formats.append({ |
||||
'format_id': con_string.split('://')[0], |
||||
'app': compat_urlparse.quote('?' + con_string.split('?')[1] + 'flvplayerapp/' + qs['appInstance'][0]), |
||||
'ext': 'flv', |
||||
'play_path': 'mp4:' + qs['streamName'][0], |
||||
'rtmp_conn': 'S:' + qs['ticket'][0], |
||||
'rtmp_live': is_live, |
||||
'url': con_string, |
||||
}) |
||||
|
||||
return { |
||||
'id': video_id, |
||||
'title': self._live_title(title) if is_live else title, |
||||
'formats': formats, |
||||
'is_live': is_live, |
||||
} |
Loading…
Reference in new issue