youtube-dl/youtube_dl/extractor/stretchinternet.py

50 lines
1.9 KiB
Python
Raw Normal View History

2017-10-25 01:50:02 +09:00
from __future__ import unicode_literals
from .common import InfoExtractor
from datetime import datetime
import pytz
2017-10-25 01:50:02 +09:00
class StretchInternetIE(InfoExtractor):
_VALID_URL = r'https?://portal\.stretchinternet\.com/[^/]+/(?:portal|full)\.htm\?.*?\beventId=(?P<id>\d+)'
2017-10-25 01:50:02 +09:00
_TEST = {
'url': 'https://portal.stretchinternet.com/umary/portal.htm?eventId=573272&streamType=video',
2017-10-25 01:50:02 +09:00
'info_dict': {
'id': '573272',
2017-10-25 01:50:02 +09:00
'ext': 'mp4',
'title': 'UNIVERSITY OF MARY WRESTLING VS UPPER IOWA',
# 'timestamp': 1575668361,
# 'upload_date': '20191206',
'uploader_id': '99997',
2017-10-25 01:50:02 +09: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-25 01:50:02 +09:00
return {
'id': video_id,
'title': event['title'],
'timestamp': self._parse_date(event.get('dateTimeString')),
'url': 'https://' + media_url,
'uploader_id': event.get('ownerID'),
2017-10-25 01:50:02 +09:00
}
def _parse_date(self, date_string):
if date_string:
# Assume date_string is in the format 'YYYY-MM-DDTHH:MM:SS-05:00'
try:
dt = datetime.strptime(date_string, '%Y-%m-%dT%H:%M:%S%z')
# Convert the datetime to UTC (if it's not already)
dt_utc = dt.astimezone(pytz.UTC)
return int(dt_utc.timestamp())
except ValueError:
self._downloader.report_warning(f"Could not parse date string: {date_string}")
return None