- player_info = ''
- for line in self._search_regex( 'var flashvars = ({[^}]+})', webpage, 'flashvars').splitlines():
- if '+' not in line and '(' not in line and ')' not in line:
- player_info += line
- player_info = self._parse_json(js_to_json(player_info), video_id)
- video_id = player_info['id']
- player_type = player_info['playerType']
-
- video_info = self._download_json(
- player_info['url'] + '/' + player_type + '/' + video_id +
- '?apiKey=sh%40hid0nlin3&hash=b2wMCTHpSmyxGqQjJFOycRmLSex%2BBpTK%2Fooxy6vHaqs%3D',
- video_id
- )['data']
- if video_info['error']:
- for error in video_info['error']:
- raise ExtractorError(error)
- video_info = video_info[player_type]
- if video_info.get('availabilities').get('plus'):
- raise ExtractorError('plus members only')
- title = video_info['title']
- thumbnail = video_info.get('thumbnailUrl')
- categories = [category['name'] for category in video_info.get('genres')]
- description = video_info.get('description')
- duration = int_or_none(video_info.get('duration'))
-
- player_json_data = self._download_json(
- 'https://shahid.mbc.net/arContent/getPlayerContent-param-.id-' + video_id + '.type-' + player_info['type'] + '.html',
- video_id
- )['data']
- if 'url' in player_json_data:
- m3u8_url = player_json_data['url']
- else:
- for error in player_json_data['error'].values():
- raise ExtractorError(error)
- return
- formats = self._extract_m3u8_formats(m3u8_url, video_id)
+
+ api_vars = {
+ 'id': video_id,
+ 'type': 'player',
+ 'url': 'http://api.shahid.net/api/v1_1',
+ 'playerType': 'episode',
+ }
+
+ flashvars = self._search_regex(
+ r'var\s+flashvars\s*=\s*({[^}]+})', webpage, 'flashvars', default=None)
+ if flashvars:
+ for key in api_vars.keys():
+ value = self._search_regex(
+ r'\b%s\s*:\s*(?P<q>["\'])(?P<value>.+?)(?P=q)' % key,
+ flashvars, 'type', default=None, group='value')
+ if value:
+ api_vars[key] = value
+
+ player = self._download_json(
+ 'https://shahid.mbc.net/arContent/getPlayerContent-param-.id-%s.type-%s.html'
+ % (video_id, api_vars['type']), video_id, 'Downloading player JSON')
+
+ if player.get('drm'):
+ raise ExtractorError('This video is DRM protected.', expected=True)
+
+ formats = self._extract_m3u8_formats(player['url'], video_id, 'mp4')
+
+ video = self._download_json(
+ '%s/%s/%s?%s' % (
+ api_vars['url'], api_vars['playerType'], api_vars['id'],
+ compat_urllib_parse.urlencode({
+ 'apiKey': 'sh@hid0nlin3',
+ 'hash': 'b2wMCTHpSmyxGqQjJFOycRmLSex+BpTK/ooxy6vHaqs=',
+ })),
+ video_id, 'Downloading video JSON')
+
+ video = video[api_vars['playerType']]
+
+ title = video['title']
+ description = video.get('description')
+ thumbnail = video.get('thumbnailUrl')
+ duration = int_or_none(video.get('duration'))
+ timestamp = parse_iso8601(video.get('referenceDate'))
+ categories = [
+ category['name']
+ for category in video.get('genres', []) if 'name' in category]
+