mirror of
https://github.com/yt-dlp/yt-dlp
synced 2025-01-25 19:58:44 +01:00
38 lines
1.3 KiB
Python
38 lines
1.3 KiB
Python
|
# 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,
|
||
|
}
|