1 from .common
import InfoExtractor
8 class MinotoIE(InfoExtractor
):
9 _VALID_URL
= r
'(?:minoto:|https?://(?:play|iframe|embed)\.minoto-video\.com/(?P<player_id>[0-9]+)/)(?P<id>[a-zA-Z0-9]+)'
11 def _real_extract(self
, url
):
12 mobj
= self
._match
_valid
_url
(url
)
13 player_id
= mobj
.group('player_id') or '1'
14 video_id
= mobj
.group('id')
15 video_data
= self
._download
_json
(f
'http://play.minoto-video.com/{player_id}/{video_id}.js', video_id
)
16 video_metadata
= video_data
['video-metadata']
18 for fmt
in video_data
['video-files']:
19 fmt_url
= fmt
.get('url')
22 container
= fmt
.get('container')
23 if container
== 'hls':
24 formats
.extend(self
._extract
_m
3u8_formats
(fmt_url
, video_id
, 'mp4', m3u8_id
='hls', fatal
=False))
26 fmt_profile
= fmt
.get('profile') or {}
28 'format_id': fmt_profile
.get('name-short'),
29 'format_note': fmt_profile
.get('name'),
31 'container': container
,
32 'tbr': int_or_none(fmt
.get('bitrate')),
33 'filesize': int_or_none(fmt
.get('filesize')),
34 'width': int_or_none(fmt
.get('width')),
35 'height': int_or_none(fmt
.get('height')),
36 **parse_codecs(fmt
.get('codecs')),
41 'title': video_metadata
['title'],
42 'description': video_metadata
.get('description'),
43 'thumbnail': video_metadata
.get('video-poster', {}).get('url'),