mirror of
https://github.com/ytdl-org/youtube-dl
synced 2025-01-07 12:00:09 +09:00
[premier.one] Add new extractor
This commit is contained in:
parent
8bf9591a70
commit
a44733c638
@ -931,6 +931,7 @@ from .puhutv import (
|
|||||||
PuhuTVIE,
|
PuhuTVIE,
|
||||||
PuhuTVSerieIE,
|
PuhuTVSerieIE,
|
||||||
)
|
)
|
||||||
|
from .premierone import PremierOneIE
|
||||||
from .presstv import PressTVIE
|
from .presstv import PressTVIE
|
||||||
from .prosiebensat1 import ProSiebenSat1IE
|
from .prosiebensat1 import ProSiebenSat1IE
|
||||||
from .puls4 import Puls4IE
|
from .puls4 import Puls4IE
|
||||||
|
127
youtube_dl/extractor/premierone.py
Normal file
127
youtube_dl/extractor/premierone.py
Normal file
@ -0,0 +1,127 @@
|
|||||||
|
# coding: utf-8
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
import re
|
||||||
|
|
||||||
|
from .common import InfoExtractor
|
||||||
|
from ..utils import (
|
||||||
|
parse_duration,
|
||||||
|
parse_iso8601,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class PremierOneIE(InfoExtractor):
|
||||||
|
_VALID_URL = r'https?://premier\.one/show/(?P<show_id>[0-9]+)(/season/(?P<season_number>\d+))?(/video/(?P<id>[0-9a-f]+))?'
|
||||||
|
_TEST = {
|
||||||
|
'url': 'https://premier.one/show/3421/season/6/video/b4766f2eeb90cbb5538729061ac3949b',
|
||||||
|
'info_dict': {
|
||||||
|
'id': 'b4766f2eeb90cbb5538729061ac3949b',
|
||||||
|
'ext': 'mp4',
|
||||||
|
'title': '32 выпуск',
|
||||||
|
'thumbnail': 'https://pic.uma.media/pic/video/06/c2/06c2cb95bb06c03c379d9d20930c5718.jpg',
|
||||||
|
'description': 'В этом выпуске шоу «Где логика?» в интеллектуальном поединке сразятся Екатерина Моргунова и Манижа против Ильи Соболева и Зураба Матуа.',
|
||||||
|
'timestamp': 1611615378,
|
||||||
|
'upload_date': '20210125',
|
||||||
|
},
|
||||||
|
'params': {
|
||||||
|
# m3u8 download
|
||||||
|
'skip_download': True,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
def _extract_video(self, video_id):
|
||||||
|
video = self._download_json(
|
||||||
|
'https://premier.one/uma-api/video/' + video_id,
|
||||||
|
video_id, 'Downloading video information ' + video_id,
|
||||||
|
headers={
|
||||||
|
'Accept': 'application/json',
|
||||||
|
'Referer': 'https://premier.one/play/embed/' + video_id + '?controlledFullscreen=true'
|
||||||
|
})
|
||||||
|
|
||||||
|
return self._extract_video_info(video)
|
||||||
|
|
||||||
|
def _extract_video_info(self, item):
|
||||||
|
video_id = item.get('id')
|
||||||
|
info = {
|
||||||
|
'id': video_id,
|
||||||
|
'title': item.get('title'),
|
||||||
|
'description': item.get('description'),
|
||||||
|
'thumbnail': item.get('thumbnail_url'),
|
||||||
|
'duration': parse_duration(item.get('duration')),
|
||||||
|
'timestamp': parse_iso8601(item.get('publication_ts')),
|
||||||
|
'comment_count': item.get('comments_count'),
|
||||||
|
'season_number': item.get('season'),
|
||||||
|
'episode_number': item.get('episode'),
|
||||||
|
'url': item.get('video_url'),
|
||||||
|
'ext': 'mp4',
|
||||||
|
}
|
||||||
|
|
||||||
|
video = self._download_json(
|
||||||
|
'https://premier.one/api/play/options/' + video_id + '/?format=json&no_404=true',
|
||||||
|
video_id, 'Downloading video ' + info.get('title'),
|
||||||
|
headers={
|
||||||
|
'Accept': 'application/json',
|
||||||
|
'Referer': 'https://premier.one/play/embed/' + video_id + '?controlledFullscreen=true'
|
||||||
|
})
|
||||||
|
if video.get('video_balancer') and video.get('video_balancer').get('default'):
|
||||||
|
formats = []
|
||||||
|
m3u8_url = video.get('video_balancer').get('default')
|
||||||
|
m3u8_formats = self._extract_m3u8_formats(
|
||||||
|
m3u8_url, video_id, 'mp4', 'm3u8_native',
|
||||||
|
fatal=False)
|
||||||
|
formats.extend(m3u8_formats)
|
||||||
|
|
||||||
|
info['formats'] = formats
|
||||||
|
|
||||||
|
return info
|
||||||
|
|
||||||
|
def _extract_show_playlist(self, show_id, season_number):
|
||||||
|
seasons = self._download_json(
|
||||||
|
'https://premier.one/uma-api/metainfo/tv/' + show_id + '/season/',
|
||||||
|
show_id, 'Downloading videos JSON',
|
||||||
|
headers={
|
||||||
|
'Accept': 'application/json',
|
||||||
|
'Referer': 'https://premier.one/show/' + show_id
|
||||||
|
})
|
||||||
|
|
||||||
|
entries = []
|
||||||
|
for season in seasons:
|
||||||
|
if season_number is not None and str(season.get('number')) != season_number:
|
||||||
|
continue
|
||||||
|
|
||||||
|
metainfo = self._download_json(
|
||||||
|
'https://premier.one/uma-api/metainfo/tv/' + show_id + '/video/?season=' + str(season.get('number')),
|
||||||
|
str(season.get('number')), 'Downloading season ' + str(season.get('number')),
|
||||||
|
headers={
|
||||||
|
'Accept': 'application/json',
|
||||||
|
'Referer': 'https://premier.one/show/' + show_id + '/season/' + str(season.get('number'))
|
||||||
|
})
|
||||||
|
while metainfo and (metainfo.get('page') == 1 or metainfo.get('has_next')):
|
||||||
|
for item in metainfo.get('results'):
|
||||||
|
video_id = item.get('id')
|
||||||
|
if not video_id:
|
||||||
|
continue
|
||||||
|
|
||||||
|
info = self._extract_video_info(item)
|
||||||
|
if info:
|
||||||
|
entries.append(info)
|
||||||
|
|
||||||
|
if metainfo.get('has_next'):
|
||||||
|
metainfo = self._download_json(
|
||||||
|
metainfo.get('next'),
|
||||||
|
str(season.get('number')), 'Downloading metainfo JSON for page ' + str(metainfo.get('page') + 1),
|
||||||
|
headers={
|
||||||
|
'Accept': 'application/json',
|
||||||
|
'Referer': 'https://premier.one/show/' + str(show_id) + '/season/' + str(season.get('number')) + '/video/' + video_id
|
||||||
|
})
|
||||||
|
else:
|
||||||
|
metainfo = None
|
||||||
|
|
||||||
|
return self.playlist_result(entries, show_id)
|
||||||
|
|
||||||
|
def _real_extract(self, url):
|
||||||
|
mobj = re.match(self._VALID_URL, url)
|
||||||
|
|
||||||
|
if mobj.group('id'):
|
||||||
|
return self._extract_video(mobj.group('id'))
|
||||||
|
else:
|
||||||
|
return self._extract_show_playlist(mobj.group('show_id'), mobj.group('season_number'))
|
Loading…
Reference in New Issue
Block a user