Compare commits

...

10 Commits

Author SHA1 Message Date
nomevi
8c05c1fca9
Merge 032aed0e41 into e1b3fa242c 2024-07-28 01:35:19 +09:00
nomevi
032aed0e41 Remove unused includes 2022-07-10 03:33:49 +02:00
nomevi
918113db3b
Break out video_url and title
Co-authored-by: dirkf <fieldhouse@gmx.net>
2022-07-10 01:33:32 +00:00
nomevi
4d02ba27d7 Use parse_iso8601 2022-07-10 01:51:41 +02:00
nomevi
ea4a9f4d98 Correct which fields are fail inducing and crash proof 2022-07-10 01:51:41 +02:00
nomevi
26dc85adb4 Use IE._download_json() 2022-07-10 01:51:41 +02:00
nomevi
c9e09d187f Rename apiResponse to api_response 2022-07-10 01:51:41 +02:00
nomevi
2d82e8a958 Refactor return 2022-07-10 01:51:41 +02:00
dirkf
129cfb174c
Add Unicode compatibility header 2022-07-08 06:54:01 +01:00
nomevi
951aa74cbe [livestreamfails] Add new extractor 2022-06-27 14:09:41 +02:00
2 changed files with 51 additions and 0 deletions

View File

@ -643,6 +643,9 @@ from .livestream import (
LivestreamOriginalIE,
LivestreamShortenerIE,
)
from .livestreamfails import (
LivestreamfailsIE,
)
from .lnkgo import LnkGoIE
from .localnews8 import LocalNews8IE
from .lovehomeporn import LoveHomePornIE

View File

@ -0,0 +1,48 @@
# coding: utf-8
from __future__ import unicode_literals
from .common import InfoExtractor
from ..utils import (
try_get,
url_or_none,
parse_iso8601,
)
from ..compat import compat_str
class LivestreamfailsIE(InfoExtractor):
_VALID_URL = r'https?://(?:www\.)?livestreamfails\.com/clip/(?P<id>[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)
video_url = 'https://livestreamfails-video-prod.b-cdn.net/video/' + api_response['videoId']
title = api_response['label']
return {
'id': id,
'url': video_url,
'title': title,
'display_id': api_response.get('sourceId'), # Twitch ID of clip
'timestamp': parse_iso8601(api_response.get('createdAt')),
'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']))
}