]>
jfr.im git - yt-dlp.git/blob - youtube_dlc/extractor/ninecninemedia.py
2 from __future__
import unicode_literals
6 from .common
import InfoExtractor
16 class NineCNineMediaIE(InfoExtractor
):
18 _GEO_COUNTRIES
= ['CA']
19 _VALID_URL
= r
'9c9media:(?P<destination_code>[^:]+):(?P<id>\d+)'
20 _API_BASE_TEMPLATE
= 'http://capi.9c9media.com/destinations/%s/platforms/desktop/contents/%s/'
22 def _real_extract(self
, url
):
23 destination_code
, content_id
= re
.match(self
._VALID
_URL
, url
).groups()
24 api_base_url
= self
._API
_BASE
_TEMPLATE
% (destination_code
, content_id
)
25 content
= self
._download
_json
(api_base_url
, content_id
, query
={
26 '$include': '[Media,Season,ContentPackages]',
28 title
= content
['Name']
29 if len(content
['ContentPackages']) > 1:
30 raise ExtractorError('multiple content packages')
31 content_package
= content
['ContentPackages'][0]
32 package_id
= content_package
['Id']
33 content_package_url
= api_base_url
+ 'contentpackages/%s/' % package_id
34 content_package
= self
._download
_json
(
35 content_package_url
, content_id
, query
={
36 '$include': '[HasClosedCaptions]',
39 if try_get(content_package
, lambda x
: x
['Constraints']['Security']['Type']):
40 raise ExtractorError('This video is DRM protected.', expected
=True)
42 manifest_base_url
= content_package_url
+ 'manifest.'
44 formats
.extend(self
._extract
_m
3u8_formats
(
45 manifest_base_url
+ 'm3u8', content_id
, 'mp4',
46 'm3u8_native', m3u8_id
='hls', fatal
=False))
47 formats
.extend(self
._extract
_f
4m
_formats
(
48 manifest_base_url
+ 'f4m', content_id
,
49 f4m_id
='hds', fatal
=False))
50 formats
.extend(self
._extract
_mpd
_formats
(
51 manifest_base_url
+ 'mpd', content_id
,
52 mpd_id
='dash', fatal
=False))
53 self
._sort
_formats
(formats
)
56 for image
in (content
.get('Images') or []):
57 image_url
= image
.get('Url')
62 'width': int_or_none(image
.get('Width')),
63 'height': int_or_none(image
.get('Height')),
66 tags
, categories
= [], []
67 for source_name
, container
in (('Tags', tags
), ('Genres', categories
)):
68 for e
in content
.get(source_name
, []):
69 e_name
= e
.get('Name')
72 container
.append(e_name
)
74 season
= content
.get('Season') or {}
79 'description': content
.get('Desc') or content
.get('ShortDesc'),
80 'timestamp': parse_iso8601(content
.get('BroadcastDateTime')),
81 'episode_number': int_or_none(content
.get('Episode')),
82 'season': season
.get('Name'),
83 'season_number': int_or_none(season
.get('Number')),
84 'season_id': season
.get('Id'),
85 'series': try_get(content
, lambda x
: x
['Media']['Name']),
87 'categories': categories
,
88 'duration': float_or_none(content_package
.get('Duration')),
90 'thumbnails': thumbnails
,
93 if content_package
.get('HasClosedCaptions'):
96 'url': manifest_base_url
+ 'vtt',
99 'url': manifest_base_url
+ 'srt',