[shahid] generic errors handling and check with flake8

pull/6277/head
remitamine 10 years ago
parent dfaba1ab95
commit 3be3c622dc

@ -1,3 +1,6 @@
# coding: utf-8
from __future__ import unicode_literals
from .common import InfoExtractor from .common import InfoExtractor
from ..utils import ( from ..utils import (
js_to_json, js_to_json,
@ -5,6 +8,7 @@ from ..utils import (
int_or_none int_or_none
) )
class ShahidIE(InfoExtractor): class ShahidIE(InfoExtractor):
_VALID_URL = r'https?://shahid\.mbc\.net/ar/episode/(?P<id>\d+)/?' _VALID_URL = r'https?://shahid\.mbc\.net/ar/episode/(?P<id>\d+)/?'
_TESTS = [ _TESTS = [
@ -23,7 +27,7 @@ class ShahidIE(InfoExtractor):
} }
}, },
{ {
#shahid plus subscriber only # shahid plus subscriber only
'url': 'https://shahid.mbc.net/ar/series/90497/%D9%85%D8%B1%D8%A7%D9%8A%D8%A7-2011.html', 'url': 'https://shahid.mbc.net/ar/series/90497/%D9%85%D8%B1%D8%A7%D9%8A%D8%A7-2011.html',
'only_matching': True 'only_matching': True
} }
@ -32,42 +36,40 @@ class ShahidIE(InfoExtractor):
def _real_extract(self, url): def _real_extract(self, url):
video_id = self._match_id(url) video_id = self._match_id(url)
webpage = self._download_webpage(url, video_id) webpage = self._download_webpage(url, video_id)
player_info = '' player_info = ''
for line in self._search_regex( 'var flashvars = ({[^}]+})', webpage, 'flashvars').splitlines(): for line in self._search_regex('var flashvars = ({[^}]+})', webpage, 'flashvars').splitlines():
if '+' not in line and '(' not in line and ')' not in line: if '+' not in line and '(' not in line and ')' not in line:
player_info += line player_info += line
player_info = self._parse_json(js_to_json(player_info), video_id) player_info = self._parse_json(js_to_json(player_info), video_id)
video_id = player_info['id'] video_id = player_info['id']
player_type = player_info['playerType'] player_type = player_info['playerType']
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)
formats = self._extract_m3u8_formats(m3u8_url, video_id)
video_info = self._download_json( video_info = self._download_json(
player_info['url'] + '/' + player_type + '/' + video_id + player_info['url'] + '/' + player_type + '/' + video_id + '?apiKey=sh%40hid0nlin3&hash=b2wMCTHpSmyxGqQjJFOycRmLSex%2BBpTK%2Fooxy6vHaqs%3D',
'?apiKey=sh%40hid0nlin3&hash=b2wMCTHpSmyxGqQjJFOycRmLSex%2BBpTK%2Fooxy6vHaqs%3D',
video_id video_id
)['data'] )['data']
if video_info['error']: if video_info.get('error'):
for error in video_info['error']: for error in video_info['error']:
raise ExtractorError(error) raise ExtractorError(error)
video_info = video_info[player_type] video_info = video_info[player_type]
if video_info.get('availabilities').get('plus'):
raise ExtractorError('plus members only')
title = video_info['title'] title = video_info['title']
thumbnail = video_info.get('thumbnailUrl') thumbnail = video_info.get('thumbnailUrl')
categories = [category['name'] for category in video_info.get('genres')] categories = [category['name'] for category in video_info.get('genres')]
description = video_info.get('description') description = video_info.get('description')
duration = int_or_none(video_info.get('duration')) 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)
return { return {
'id': video_id, 'id': video_id,
'title': title, 'title': title,

Loading…
Cancel
Save