# coding: utf-8 from __future__ import unicode_literals from .common import InfoExtractor import time import calendar from ..utils import ( try_get, url_or_none, ) from ..compat import compat_str class LivestreamfailsIE(InfoExtractor): _VALID_URL = r'https?://(?:www\.)?livestreamfails\.com/clip/(?P[0-9]+)' _TESTS = [{ 'url': 'https://livestreamfails.com/clip/139200', 'md5': '8a03aea1a46e94a05af6410337463102', 'info_dict': { 'id': '139200', 'ext': 'mp4', 'display_id': 'ConcernedLitigiousSalmonPeteZaroll-O8yo9W2L8OZEKhV2', 'title': 'Streamer jumps off a trampoline at full speed', 'creator': 'paradeev1ch', 'thumbnail': 'https://livestreamfails-image-prod.b-cdn.net/image/3877b1d38db083fa25c82685bbaf645637e575ea.png', 'timestamp': 1656271785, 'upload_date': '20220626', } }] def _real_extract(self, url): id = self._match_id(url) # https://livestreamfails.com/clip/id uses https://api.livestreamfails.com/clip/ to fetch the video metadata # Use the same endpoint here to avoid loading and parsing the provided page (which requires JS) api_response = self._download_json('https://api.livestreamfails.com/clip/' + id, id) # Get the input timestamp (test case gives 2022-06-26T19:29:45.515Z) timestamp = api_response.get('createdAt') if(timestamp): # Parse it into a struct_time timestamp = time.strptime(timestamp, '%Y-%m-%dT%H:%M:%S.%fZ') # Convert the struct_time to a UNIX timestamp while ignoring the local timezone attached by time.strptime() timestamp = calendar.timegm(timestamp) return { 'id': id, 'url': 'https://livestreamfails-video-prod.b-cdn.net/video/' + api_response['videoId'], 'title': api_response['label'], 'display_id': api_response.get('sourceId'), # Twitch ID of clip 'timestamp': timestamp, 'creator': try_get(api_response, lambda x: x['streamer']['label'], compat_str), 'thumbnail': url_or_none(try_get(api_response, lambda x: 'https://livestreamfails-image-prod.b-cdn.net/image/' + x['imageId'])) }