1
1
mirror of https://github.com/ytdl-org/youtube-dl synced 2024-12-11 17:27:50 +01:00
youtube-dl/youtube_dl/extractor/stretchinternet.py

38 lines
1.3 KiB
Python
Raw Normal View History

2017-10-24 18:50:02 +02:00
from __future__ import unicode_literals
from .common import InfoExtractor
class StretchInternetIE(InfoExtractor):
_VALID_URL = r'https?://portal\.stretchinternet\.com/[^/]+/(?:portal|full)\.htm\?.*?\beventId=(?P<id>\d+)'
2017-10-24 18:50:02 +02:00
_TEST = {
'url': 'https://portal.stretchinternet.com/umary/portal.htm?eventId=573272&streamType=video',
2017-10-24 18:50:02 +02:00
'info_dict': {
'id': '573272',
2017-10-24 18:50:02 +02:00
'ext': 'mp4',
'title': 'UNIVERSITY OF MARY WRESTLING VS UPPER IOWA',
# 'timestamp': 1575668361,
# 'upload_date': '20191206',
'uploader_id': '99997',
2017-10-24 18:50:02 +02:00
}
}
def _real_extract(self, url):
video_id = self._match_id(url)
media_url = self._download_json(
'https://core.stretchlive.com/trinity/event/tcg/' + video_id,
video_id)[0]['media'][0]['url']
event = self._download_json(
'https://neo-client.stretchinternet.com/portal-ws/getEvent.json',
video_id, query={'eventID': video_id, 'token': 'asdf'})['event']
2017-10-24 18:50:02 +02:00
return {
'id': video_id,
'title': event['title'],
# TODO: parse US timezone abbreviations
# 'timestamp': event.get('dateTimeString'),
'url': 'https://' + media_url,
'uploader_id': event.get('ownerID'),
2017-10-24 18:50:02 +02:00
}