Compare commits

...

3 Commits

Author SHA1 Message Date
Elan Ruusamäe
d15516543b
Merge 886ae0c277 into fe70f20aed 2024-11-23 22:49:31 +01:00
bashonly
886ae0c277
get session token 2024-11-20 15:24:36 +00:00
Elan Ruusamäe
50cdbbaf9c Add new url format to duoplay
- https://duoplay.ee/9644?ep=184
2024-11-20 11:41:29 +02:00

View File

@ -8,12 +8,14 @@ from ..utils import (
str_or_none,
try_call,
unified_timestamp,
update_url_query,
)
from ..utils.traversal import traverse_obj
class DuoplayIE(InfoExtractor):
_VALID_URL = r'https?://duoplay\.ee/(?P<id>\d+)/[\w-]+/?(?:\?(?:[^#]+&)?ep=(?P<ep>\d+))?'
# https://duoplay.ee/9644?ep=185
_VALID_URL = r'https?://duoplay\.ee/(?P<id>\d+)(?:/[\w-]+/?(?:\?(?:[^#]+&))?ep=(?P<ep>\d+))?'
_TESTS = [{
'note': 'Siberi võmm S02E12',
'url': 'https://duoplay.ee/4312/siberi-vomm?ep=24',
@ -79,11 +81,20 @@ class DuoplayIE(InfoExtractor):
if not video_player or not video_player.get('manifest-url'):
raise ExtractorError('No video found', expected=True)
manifest_url = video_player['manifest-url']
session_token = self._download_json(
'https://sts.postimees.ee/session/register', video_id, 'Registering session',
'Unable to register session', headers={
'Accept': 'application/json',
'X-Original-URI': manifest_url,
})['session']
manifest_url = update_url_query(manifest_url, {'s': session_token})
episode_attr = self._parse_json(video_player.get(':episode') or '', video_id, fatal=False) or {}
return {
'id': video_id,
'formats': self._extract_m3u8_formats(video_player['manifest-url'], video_id, 'mp4'),
'formats': self._extract_m3u8_formats(manifest_url, video_id, 'mp4'),
**traverse_obj(episode_attr, {
'title': 'title',
'description': 'synopsis',