]>
jfr.im git - yt-dlp.git/blob - yt_dlp/extractor/tv2hu.py
2 from .common
import InfoExtractor
9 class TV2HuIE(InfoExtractor
):
10 IE_NAME
= 'tv2play.hu'
11 _VALID_URL
= r
'https?://(?:www\.)?tv2play\.hu/(?!szalag/)(?P<id>[^#&?]+)'
13 'url': 'https://tv2play.hu/mintaapak/mintaapak_213_epizod_resz',
17 'title': 'Mintaapák - 213. epizód',
18 'series': 'Mintaapák',
20 'description': 'md5:7350147e75485a59598e806c47967b07',
21 'thumbnail': r
're:^https?://.*\.jpg$',
22 'release_date': '20210825',
23 'season_number': None,
24 'episode_number': 213,
27 'skip_download': True,
30 'url': 'https://tv2play.hu/taxi_2',
31 'md5': '585e58e2e090f34603804bb2c48e98d8',
38 'description': 'md5:47762155dc9a50241797ded101b1b08c',
39 'thumbnail': r
're:^https?://.*\.jpg$',
40 'release_date': '20210118',
41 'season_number': None,
42 'episode_number': None,
45 'skip_download': True,
49 def _real_extract(self
, url
):
50 id = self
._match
_id
(url
)
51 json_data
= self
._download
_json
(f
'https://tv2play.hu/api/search/{id}', id)
53 if json_data
['contentType'] == 'showpage':
54 ribbon_ids
= traverse_obj(json_data
, ('pages', ..., 'tabs', ..., 'ribbonIds'), get_all
=False, expected_type
=list)
55 entries
= [self
.url_result(f
'https://tv2play.hu/szalag/{ribbon_id}',
56 ie
=TV2HuSeriesIE
.ie_key(), video_id
=ribbon_id
) for ribbon_id
in ribbon_ids
]
57 return self
.playlist_result(entries
, playlist_id
=id)
58 elif json_data
['contentType'] != 'video':
59 raise UnsupportedError(url
)
61 video_id
= str(json_data
['id'])
62 player_id
= json_data
.get('playerId')
63 series_json
= json_data
.get('seriesInfo', {})
65 video_json_url
= self
._download
_json
(f
'https://tv2play.hu/api/streaming-url?playerId={player_id}', video_id
)['url']
66 video_json
= self
._download
_json
(video_json_url
, video_id
)
67 m3u8_url
= self
._proto
_relative
_url
(traverse_obj(video_json
, ('bitrates', 'hls')))
68 formats
, subtitles
= self
._extract
_m
3u8_formats
_and
_subtitles
(m3u8_url
, video_id
)
69 self
._sort
_formats
(formats
)
73 'title': json_data
['title'],
74 'series': json_data
.get('seriesTitle'),
75 'duration': json_data
.get('length'),
76 'description': json_data
.get('description'),
77 'thumbnail': 'https://tv2play.hu' + json_data
.get('thumbnailUrl'),
78 'release_date': json_data
.get('uploadedAt').replace('.', ''),
79 'season_number': series_json
.get('seasonNr'),
80 'episode_number': series_json
.get('episodeNr'),
82 'subtitles': subtitles
,
86 class TV2HuSeriesIE(InfoExtractor
):
87 IE_NAME
= 'tv2playseries.hu'
88 _VALID_URL
= r
'https?://(?:www\.)?tv2play\.hu/szalag/(?P<id>[^#&?]+)'
91 'url': 'https://tv2play.hu/szalag/59?rendezes=nepszeruseg',
92 'playlist_mincount': 284,
98 def _real_extract(self
, url
):
99 id = self
._match
_id
(url
)
100 json_data
= self
._download
_json
(f
'https://tv2play.hu/api/ribbons/{id}/0?size=100000', id)
102 for card
in json_data
.get('cards', []):
103 video_id
= card
.get('slug')
105 entries
.append(self
.url_result(f
'https://tv2play.hu/{video_id}',
106 ie
=TV2HuIE
.ie_key(), video_id
=video_id
))
108 return self
.playlist_result(entries
, playlist_id
=id)