1
0
mirror of https://github.com/yt-dlp/yt-dlp.git synced 2025-06-27 08:58:30 +00:00
yt-dlp/yt_dlp/extractor/easybroadcast.py
CasperMcFadden95 d830162b46
Update yt_dlp/extractor/easybroadcast.py
Co-authored-by: doe1080 <98906116+doe1080@users.noreply.github.com>
2025-06-23 21:07:17 +00:00

87 lines
2.8 KiB
Python

from .common import InfoExtractor
from ..utils import ExtractorError
class EasyBroadcastLiveIE(InfoExtractor):
_VALID_URL = r'https?://(?:\w+\.)?player\.easybroadcast\.io/events/(?P<id>\w+)'
_EMBED_REGEX = [rf'<iframe[^>]+\bsrc\s*=\s*["\'](?P<url>{_VALID_URL})']
_TESTS = [{
'url': 'https://al24.player.easybroadcast.io/events/66_al24_u4yga6h',
'info_dict': {
'id': '66_al24_u4yga6h',
'title': str,
'ext': 'mp4',
'live_status': 'is_live',
},
'params': {
'nocheckcertificate': True,
'skip_download': 'Livestream',
},
}, {
'url': 'https://snrt.player.easybroadcast.io/events/73_aloula_w1dqfwm',
'info_dict': {
'id': '73_aloula_w1dqfwm',
'title': str,
'ext': 'mp4',
'live_status': 'is_live',
},
'params': {
'nocheckcertificate': True,
'skip_download': 'Livestream',
},
}]
_WEBPAGE_TESTS = [{
'url': 'https://al24news.dz/en/live',
'info_dict': {
'id': '66_al24_u4yga6h',
'title': str,
'ext': 'mp4',
'live_status': 'is_live',
},
'params': {
'nocheckcertificate': True,
'skip_download': 'Livestream',
},
}, {
'url': 'https://snrtlive.ma/fr/al-aoula',
'info_dict': {
'id': '73_aloula_w1dqfwm',
'title': str,
'ext': 'mp4',
'live_status': 'is_live',
},
'params': {
'nocheckcertificate': True,
'skip_download': 'Livestream',
},
}]
def _real_extract(self, url):
event_id = self._match_id(url)
base_url = url.split('/events/')[0]
api_url = f'{base_url}/api/events/{event_id}'
metadata = self._download_json(api_url, event_id, note='Downloading EasyBroadcast event metadata')
m3u8_url = metadata.get('stream')
token = None
if metadata.get('token_authentication', False):
token_api_url = f'https://token.easybroadcast.io/all?url={m3u8_url}'
token = self._download_webpage(token_api_url, event_id, note='Fetching stream token').strip()
m3u8_url = m3u8_url + '?' + token
if not token:
raise ExtractorError('Empty token returned from token server.')
formats = self._extract_m3u8_formats(m3u8_url, video_id=event_id, ext='mp4', m3u8_id='hls', live=True)
if token:
for fmt in formats:
fmt['url'] = fmt['url'] + '?' + token
return {
'id': event_id,
'title': metadata.get('name', event_id),
'formats': formats,
'is_live': True,
}