]>
Raphaƫl G. Git Repositories - youtubedl/blob - youtube_dl/extractor/hotstar.py
2 from __future__
import unicode_literals
8 from .common
import InfoExtractor
9 from ..compat
import compat_HTTPError
18 class HotStarBaseIE(InfoExtractor
):
19 _AKAMAI_ENCRYPTION_KEY
= b
'\x05\xfc\x1a\x01\xca\xc9\x4b\xc4\x12\xfc\x53\x12\x07\x75\xf9\xee'
21 def _call_api(self
, path
, video_id
, query_name
='contentId'):
24 auth
= 'st=%d~exp=%d~acl=/*' % (st
, exp
)
25 auth
+= '~hmac=' + hmac
.new(self
._AKAMAI
_ENCRYPTION
_KEY
, auth
.encode(), hashlib
.sha256
).hexdigest()
26 response
= self
._download
_json
(
27 'https://api.hotstar.com/' + path
,
30 'x-country-code': 'IN',
31 'x-platform-code': 'JIO',
36 if response
['statusCode'] != 'OK':
38 response
['body']['message'], expected
=True)
39 return response
['body']['results']
42 class HotStarIE(HotStarBaseIE
):
44 _VALID_URL
= r
'https?://(?:www\.)?hotstar\.com/(?:.+?[/-])?(?P<id>\d{10})'
46 'url': 'https://www.hotstar.com/can-you-not-spread-rumours/1000076273',
50 'title': 'Can You Not Spread Rumours?',
51 'description': 'md5:c957d8868e9bc793ccb813691cc4c434',
52 'timestamp': 1447248600,
53 'upload_date': '20151111',
58 'skip_download': True,
61 'url': 'http://www.hotstar.com/sports/cricket/rajitha-sizzles-on-debut-with-329/2001477583',
62 'only_matching': True,
64 'url': 'http://www.hotstar.com/1000000515',
65 'only_matching': True,
69 def _real_extract(self
, url
):
70 video_id
= self
._match
_id
(url
)
72 webpage
= self
._download
_webpage
(url
, video_id
)
73 app_state
= self
._parse
_json
(self
._search
_regex
(
74 r
'<script>window\.APP_STATE\s*=\s*({.+?})</script>',
75 webpage
, 'app state'), video_id
)
77 for v
in app_state
.values():
78 content
= try_get(v
, lambda x
: x
['initialState']['contentData']['content'], dict)
79 if content
and content
.get('contentId') == video_id
:
82 title
= video_data
['title']
84 if video_data
.get('drmProtected'):
85 raise ExtractorError('This video is DRM protected.', expected
=True)
88 format_data
= self
._call
_api
('h/v1/play', video_id
)['item']
89 format_url
= format_data
['playbackUrl']
90 ext
= determine_ext(format_url
)
93 formats
.extend(self
._extract
_m
3u8_formats
(
94 format_url
, video_id
, 'mp4', m3u8_id
='hls'))
95 except ExtractorError
as e
:
96 if isinstance(e
.cause
, compat_HTTPError
) and e
.cause
.code
== 403:
97 self
.raise_geo_restricted(countries
=['IN'])
100 # produce broken files
105 'width': int_or_none(format_data
.get('width')),
106 'height': int_or_none(format_data
.get('height')),
108 self
._sort
_formats
(formats
)
113 'description': video_data
.get('description'),
114 'duration': int_or_none(video_data
.get('duration')),
115 'timestamp': int_or_none(video_data
.get('broadcastDate') or video_data
.get('startDate')),
117 'channel': video_data
.get('channelName'),
118 'channel_id': video_data
.get('channelId'),
119 'series': video_data
.get('showName'),
120 'season': video_data
.get('seasonName'),
121 'season_number': int_or_none(video_data
.get('seasonNo')),
122 'season_id': video_data
.get('seasonId'),
124 'episode_number': int_or_none(video_data
.get('episodeNo')),
128 class HotStarPlaylistIE(HotStarBaseIE
):
129 IE_NAME
= 'hotstar:playlist'
130 _VALID_URL
= r
'https?://(?:www\.)?hotstar\.com/tv/[^/]+/s-\w+/list/[^/]+/t-(?P<id>\w+)'
132 'url': 'https://www.hotstar.com/tv/savdhaan-india/s-26/list/popular-clips/t-3_2_26',
136 'playlist_mincount': 20,
138 'url': 'https://www.hotstar.com/tv/savdhaan-india/s-26/list/extras/t-2480',
139 'only_matching': True,
142 def _real_extract(self
, url
):
143 playlist_id
= self
._match
_id
(url
)
145 collection
= self
._call
_api
('o/v1/tray/find', playlist_id
, 'uqId')
149 'https://www.hotstar.com/%s' % video
['contentId'],
150 ie
=HotStarIE
.ie_key(), video_id
=video
['contentId'])
151 for video
in collection
['assets']['items']
152 if video
.get('contentId')]
154 return self
.playlist_result(entries
, playlist_id
)